Sybase数据库Top问题的解决 (转)

Sybase数据库Top问题的解决  

 

我们知道,在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下测试通过。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值