查询某张表中某些列一样的记录
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;
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;