mysql的limit offset后面不能跟变量 只能硬编码数字的问题

今天在写mysql存储过程的时候遇到一问题

mysql版本呢:5.1.40

不知道高一点的版本有无此问题

如果高版本不存在此问题亲跳过

 

sql如下:

SELECT pid,NAMES INTO _dp_id,_dp_names FROM department LIMIT 1 OFFSET _dp_count;


_dp_count是我声明的一变量

 

执行的时候报错...

 

 

错误码: 1064
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '_dp_count;

 

原来 mysql的 limit 和 offset后面都不能跟变量

 

解决方法是用 CONCAT 把sql拼起来

 

然后PREPARE 再EXECUTE 就OK了 

 

 

 

我试了postgreSQL9.0.10 不存在此问题

 

 

 

不知道其他数据库会有此问题不

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值