Sybase数据库Top问题的解决

作者在 2007-07-18 21:00:00 发布以下内容

我们知道,在SQLServer数据里,如果要返回数据表里前多少行数据时,使用

Select Top n 列名列表 From 表名列表 ...

这样的 SQL 语句即可。

可是,这样的语句在 Sybase 数据库里是行不通的(报错),那我们在怎样解决这个问题呢?实际上,这两种数据库都有一个设置,叫

Set RowCount n

这个设置将影响返回的数据行数。

利用这个设置,则在Sybase 中可以这样解决:

Set RowCount n Select 列名列表 From 表名列表 ....

例如:

Set RowCount 100 Select * From EveryOne

即从 EveryOne 表里返回前100条记录。

 

在 SQLServer 2000 和 Sybase Server 12 上测试通过。如果我们程序经常要跨 Sybase 和 SQLServer 的话,不妨用这种结构,以提高程序可移植性能。

 注意:

在PB中,这种写法不被支持。

但可以这样解决:

1、第一条虚SQL代码,即写一条只返回少量记录或不返回记录的SQL语句,在SQL语句后加 Set RowCount n。例如:Select * From EveryOne Where ID > '999999999999999999999' Set RowCount 1。

2、第二条真实SQL代码,后再恢复为 0。例如: Select * From EveryOne Set RowCount 0。

这样第二语句将只返回一条记录了。

PB9.03下测试通过。

 

 

 

SQL研究 | 阅读 2244 次
文章评论,共0条
游客请输入验证码
浏览49534次