sql经典语句

查询某张表中某些列一样的记录
selelect * from tableName
group by column1,column2
having count(*) > 1;


表中某个字符串中部分字符用其他字符代替
update NEWRESOURCE set CODE = REPLACE (CODE ,'0040','004') where CODE like '0040%' ;


有关分页的Sql语句
MySql数据库:
是利用mysql的LIMIT函数,LIMIT [offset,] rows从数据库表中M条记录开始检索N条记录的语句为:
   SELECT * FROM 表名称 LIMIT M,N 
M代表从第几条记录开始,N代表查询多少条记录
  使用limit关键字,第一个"?"是起始行号,第二个"?"是返回条目数
SqlServer数据库
假设有80条记录,每页显示10条记录,id 从1到80,现在按照id升序排列取出第三页的数据应该为:所取得记录的id 应该为 21到30。 
这时该语句应该为:
select * from (
   select TOP 10 * FROM (
 SELECT TOP 30   * from user_table
   ORDER BY id ASC ) as aSysTable
   ORDER BY id DESC ) as bSysTable
   ORDER BY id ASC 
原理如下: 
(1)先按照id从小到大升序取出30条记录(3*10),也就是:id 在 1-30 之间的记 录 (SELECT TOP 30   * from user_table   ORDER BY id ASC) 
(2)然后按照ID降序排列这30条记录,得到记录为id 在:从30到 1   
(3)然后在这些30条记录中取出前10条记录:取得的记录为:id 在30-21之间。这就是我们需要的数据,但这时是按照降序排列的,不符合要求。 
(4)最后在重新排序得到最终我们需要的数据。id在21-30之间。

Oracel数据库:
select * from (
select rownumr, all_objects.* 
from all_objects  
where rownum <=49) t
where t.r >= 30; 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值