SQL语句SELECT TOP用法小结
2010-04-06 20:17
851 查看
马上本地localhost测试,果然,我发布了一条3个月前的标题相同的信息,系统也提示重复信息,拒绝发布;而这个3个月前的id数字距现在有2万多了的差距了,远远超出了我的select top 30的查询了。
打开代码,数据库为mssql 2000:
dim rs,sql
Set rs = Server.CreateObject ("ADODB.Recordset")
sql="select top 30 * from data where title='"&title1&"' order by id desc"
rs.Open sql,conn,1,3
if rs.eof then
'入库操作
else
'重复,拒绝发布
end if
上面的这段代码是有错误的。它和我的原意相反。sql语句里同时存在where和top语句的时候,并且where条件列不是合适的索引,程序执行的是全表扫描,首先是查找符合where条件的记录,而这里的top限制形同虚设。如果全表是百万级别以上的数据表,那么就这么一个简单的判断,就有可能拖垮数据库。
我们可以采用变通的方法,就是去掉sql查询里的where条件,放入到循环体内做判断;比如采用piaoyi以下这样的代码:
dim rs,sql,cf
cf=0 '初始化重复标识为0
Set rs = Server.CreateObject ("ADODB.Recordset")
sql="select top 30 * from data order by id desc"
rs.Open sql,conn,1,3
do while not rs.eof
if rs("title")=title1 and datediff("h",rs("time"),now())<24 then
'标题相同,且在24小时内发帖
cf=1 ''重复标识为1
exit do
end if
rs.movenext
loop
if cf=0 then
'入库操作
elseif cf=1 then
'拒绝发布重复信息
end if
如果你希望使用selcet top语句,并且还要附带where条件,那么条件中的列就得是合适的索引,如聚集索引、复合索引里的主列等,同时,where条件里也要尽量避开使用函数,or,判断NULL等会引起全部扫描的语句。这一点要记住,不然执行的是全表扫描。
另外,也有人问道,如何选出第N条到第2N条记录呢。这样的sql语句就可以了:
“select top n * from TABLE_NAME where id not in (select top n id from TABLE_NAME order by id desc) order by id desc”。
打开代码,数据库为mssql 2000:
dim rs,sql
Set rs = Server.CreateObject ("ADODB.Recordset")
sql="select top 30 * from data where title='"&title1&"' order by id desc"
rs.Open sql,conn,1,3
if rs.eof then
'入库操作
else
'重复,拒绝发布
end if
上面的这段代码是有错误的。它和我的原意相反。sql语句里同时存在where和top语句的时候,并且where条件列不是合适的索引,程序执行的是全表扫描,首先是查找符合where条件的记录,而这里的top限制形同虚设。如果全表是百万级别以上的数据表,那么就这么一个简单的判断,就有可能拖垮数据库。
我们可以采用变通的方法,就是去掉sql查询里的where条件,放入到循环体内做判断;比如采用piaoyi以下这样的代码:
dim rs,sql,cf
cf=0 '初始化重复标识为0
Set rs = Server.CreateObject ("ADODB.Recordset")
sql="select top 30 * from data order by id desc"
rs.Open sql,conn,1,3
do while not rs.eof
if rs("title")=title1 and datediff("h",rs("time"),now())<24 then
'标题相同,且在24小时内发帖
cf=1 ''重复标识为1
exit do
end if
rs.movenext
loop
if cf=0 then
'入库操作
elseif cf=1 then
'拒绝发布重复信息
end if
如果你希望使用selcet top语句,并且还要附带where条件,那么条件中的列就得是合适的索引,如聚集索引、复合索引里的主列等,同时,where条件里也要尽量避开使用函数,or,判断NULL等会引起全部扫描的语句。这一点要记住,不然执行的是全表扫描。
另外,也有人问道,如何选出第N条到第2N条记录呢。这样的sql语句就可以了:
“select top n * from TABLE_NAME where id not in (select top n id from TABLE_NAME order by id desc) order by id desc”。
相关文章推荐
- SQL语句SELECT TOP用法小结(转)
- SQL语句SELECT TOP用法小结(转)
- sql语句中select top n与oracle的rownum与mysql的limit用法
- sql语句中select top n与oracle的rownum与mysql的limit用法
- sql语句中select top n与oracle的rownum与mysql的limit用法
- 小心 SQL语句SELECT TOP 的用法
- “取出数据表中第10条到第20条记录”的sql语句+select top 用法
- sql语句中select top n与oracle的rownum与mysql的limit用法
- SQL语句 SELECT LIKE like用法详解
- sql语句中select……as的用法
- SQL语句 SELECT LIKE like用法详解
- SQL 基础:Select语句,各种join,union用法
- SQL语句 SELECT LIKE like用法详解
- SQL语句 SELECT LIKE like用法详解
- SQL——select语句的三种基本用法:连接,嵌套,exists
- SQL 基础:Select语句,各种join,union用法
- SQL语句 SELECT LIKE 用法详解
- 数据库SQL语句 SELECT LIKE like用法详解
- SQL语句 SELECT LIKE like用法详解
- SQL语句的写法:Update、Case、 Select 一起的用法