mysql创建的函数中查询不能返回汉语的问题

在创建函数时

delimiter  //
create function name_student3(aa int )
returns char(50)
begin
return (select 姓名 from student where 学号=aa);
end  //
delimiter ;

遇见
15:26:26 select name_student(102) LIMIT 0, 1000 Error Code: 1366. Incorrect string value: ‘\xE5\xBC\xA0\xE4\xB8\x96…’ for column ‘name_student(102)’ at row 11 0.062 sec
语句select 姓名 from student where 学号=aa直接执行没有问题,在返回类型后加上charset utf8mb4即可。

delimiter  //
create function name_student3(aa int )
returns char(50) charset utf8mb4
begin
return (select 姓名 from student where 学号=aa);
end  //
delimiter ;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL 函数只能返回一个标量值,不能直接返回表格。但是我们可以使用临时表或表变量来模拟返回表格的效果。 下面是使用临时表的示例: ```sql CREATE FUNCTION my_func() RETURNS INT BEGIN CREATE TEMPORARY TABLE temp_table ( id INT, name VARCHAR(50) ); INSERT INTO temp_table VALUES (1, 'Alice'), (2, 'Bob'), (3, 'Charlie'); DECLARE total_count INT DEFAULT 0; SELECT COUNT(*) INTO total_count FROM temp_table; DROP TEMPORARY TABLE temp_table; RETURN total_count; END; ``` 在这个例子,我们创建了一个临时表 `temp_table`,并向其插入了一些数据。然后我们使用 `SELECT COUNT(*)` 查询了表记录的总数,并将结果赋值给变量 `total_count`。最后,我们删除了临时表并返回 `total_count`。 如果你希望在函数返回一个真正的表格,可以考虑使用表变量。下面是使用表变量的示例: ```sql CREATE FUNCTION my_func() RETURNS INT BEGIN DECLARE my_table TABLE ( id INT, name VARCHAR(50) ); INSERT INTO my_table VALUES (1, 'Alice'), (2, 'Bob'), (3, 'Charlie'); DECLARE total_count INT DEFAULT 0; SELECT COUNT(*) INTO total_count FROM my_table; RETURN total_count; END; ``` 在这个例子,我们使用 `DECLARE my_table TABLE` 声明了一个表变量 `my_table`,并向其插入了一些数据。然后我们使用 `SELECT COUNT(*)` 查询了表变量记录的总数,并将结果赋值给变量 `total_count`。最后,我们返回 `total_count`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值