MySql 实现ROW_NUMBER()

老猿的春天 2015-10-26 11:25:55
我代码中使用 otl 通过ODBC连接MySql, 执行语句时抛出异常,找不到原因
代码如下

otl_stream os_db;
try
{
os_db.open(100,"select @curRow := @curRow + 1 as rowno,t.name from (select @curRow:= 0) t, emploee t ",conn_db);
while (!os_db.eof())
{
}

}
catch(otl_exception *e)
{
}
catch(...)
{
//执行open语句进入到此处。。!!!!!!!!
}
...全文
573 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
ACMAIN_CHM 2015-10-27
  • 打赏
  • 举报
回复
http://blog.csdn.net/acmain_chm/article/details/4095531 MySQL中的ROWNUM的实现 MySQL 几乎模拟了 Oracle,SQL Server等商业数据库的大部分功能,函数。但很可惜,到目前的版本(5.1.33)为止,仍没有实现ROWNUM这个功能。 下面介绍几种具体的实现方法.建立实验环境如下mysql> create table tbl ( -> id int primary key, -> col int -> );Que...
wwwwb 2015-10-27
  • 打赏
  • 举报
回复
如果表中有唯一标识的字段,可以用查询来解决
道玄希言 2015-10-26
  • 打赏
  • 举报
回复
查询语句我用sqlyog测试倒是能通过。。。
LongRui888 2015-10-26
  • 打赏
  • 举报
回复
from (select @curRow:= 0) t, emploee t 你看看是不是 你的两个表的别称都是 t 导致的
benluobo 2015-10-26
  • 打赏
  • 举报
回复
贴出查询语句,表结构以及出错的信息
LongRui888 2015-10-26
  • 打赏
  • 举报
回复
引用 6 楼 mfc5158 的回复:
[quote=引用 5 楼 yupeigu 的回复:] [quote=引用 4 楼 mfc5158 的回复:] [quote=引用 2 楼 yupeigu 的回复:] from (select @curRow:= 0) t, emploee e 你看看是不是 你的两个表的别称都是 t 导致的
别称是我贴代码写错了,不是别称的问题,用OTL_Stream open执行变量语句就报错[/quote] 我猜也是里面包含了@变量导致的,但是光看你的代码,看不出哪儿有问题。另外,你用的是 OTL_ODBC_MYSQL 这个吧,适用于mysql的[/quote] 是定义的OTL_ODBC_MYSQL 目前执行不使用@变量的查询语句都是正常的,使用了变量查询语句就报错,异常是 [/quote] 那就不用@变量吧,还有其他的方法,用过这个也可以实现 row_number的效果:
select (select count(*) from emploee t1 where t1.主键 <= t.主键 ) as rowno,t.name  from emploee  t
老猿的春天 2015-10-26
  • 打赏
  • 举报
回复
引用 5 楼 yupeigu 的回复:
[quote=引用 4 楼 mfc5158 的回复:]
[quote=引用 2 楼 yupeigu 的回复:]

from (select @curRow:= 0) t, emploee e

你看看是不是 你的两个表的别称都是 t 导致的


别称是我贴代码写错了,不是别称的问题,用OTL_Stream open执行变量语句就报错[/quote]

我猜也是里面包含了@变量导致的,但是光看你的代码,看不出哪儿有问题。另外,你用的是 OTL_ODBC_MYSQL 这个吧,适用于mysql的[/quote]

是定义的OTL_ODBC_MYSQL
目前执行不使用@变量的查询语句都是正常的,使用了变量查询语句就报错,异常是
LongRui888 2015-10-26
  • 打赏
  • 举报
回复
引用 4 楼 mfc5158 的回复:
[quote=引用 2 楼 yupeigu 的回复:] from (select @curRow:= 0) t, emploee e 你看看是不是 你的两个表的别称都是 t 导致的
别称是我贴代码写错了,不是别称的问题,用OTL_Stream open执行变量语句就报错[/quote] 我猜也是里面包含了@变量导致的,但是光看你的代码,看不出哪儿有问题。另外,你用的是 OTL_ODBC_MYSQL 这个吧,适用于mysql的
老猿的春天 2015-10-26
  • 打赏
  • 举报
回复
引用 2 楼 yupeigu 的回复:
from (select @curRow:= 0) t, emploee e 你看看是不是 你的两个表的别称都是 t 导致的
别称是我贴代码写错了,不是别称的问题,用OTL_Stream open执行变量语句就报错

56,678

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧