度量快速开发平台-专业、快速的软件定制快开平台
标题: 项目中常见数据库知识 [打印本页]
作者: fteair 时间: 2020-6-10 14:33
标题: 项目中常见数据库知识
分页sqlserver
sqlserver一般通过not in/row_number()(不支持limit)一共两种,网上还有一种是要在2012版本之后的,我没弄过就不写了
- select top (pageNum) 字段1,字段2
- from 表名
- where id not in (
- select top (page*pageNum) 字段1,字段2 from 表名 order by id
- ) order by id
- ==========》需要page当前页页数,pageNum当前页显示条数 思路是:通过not in查数据,需要一个排序的字段
- 示例:select top 10 * from users where pid not in (select top 0 pid from users order by pid) order by pid
复制代码- select top (pageNum)
- from(
- select ROW_NUMBER() over ( order by pid ) rownumber , *
- from 表名 =====>获取全部的数据
- ) A
- where rownumber > (page*pageNum);====》这个全部数据的rownumber大于这个数
- 示例:select top 10 from (select ROW_NUMBER() over ( order by pid ) rownumber,* from users ) A where rownumber>0
复制代码
mysql
mysql的分页一般都是通过limit来的(不支持top)
- select * from 表名 limit m,n ===>m表示从第几个开始,n表示当前页显示条数 m=(当前页-1)*当前页的数目
- 示例:select* from users limit 0,10
复制代码
null值 (null在数据库中表示没有对这列数据赋值)
查询数据库中null值,是不能使用“ =null ”或者” =“” ”(需要提一点的适null的长度是null,""的长度是0),而是使用is null/ is not null
sqlserver中的covert()函数的转换格式描述
具体的转换格式在下面的例子中可以看到,列举的是当前时间
- SELECT CONVERT(varchar(100), GETDATE(), 0): 05 16 2006 10:57AM
- SELECT CONVERT(varchar(100), GETDATE(), 1): 05/16/06
- SELECT CONVERT(varchar(100), GETDATE(), 2): 06.05.16
- SELECT CONVERT(varchar(100), GETDATE(), 3): 16/05/06
- SELECT CONVERT(varchar(100), GETDATE(), 4): 16.05.06
- SELECT CONVERT(varchar(100), GETDATE(), 5): 16-05-06
- SELECT CONVERT(varchar(100), GETDATE(), 6): 16 05 06
- SELECT CONVERT(varchar(100), GETDATE(), 7): 05 16, 06
- SELECT CONVERT(varchar(100), GETDATE(), 8): 10:57:46
- SELECT CONVERT(varchar(100), GETDATE(), 9): 05 16 2006 10:57:46:827AM
- SELECT CONVERT(varchar(100), GETDATE(), 10): 05-16-06
- SELECT CONVERT(varchar(100), GETDATE(), 11): 06/05/16
- SELECT CONVERT(varchar(100), GETDATE(), 12): 060516
- SELECT CONVERT(varchar(100), GETDATE(), 13): 16 05 2006 10:57:46:937
- SELECT CONVERT(varchar(100), GETDATE(), 14): 10:57:46:967
- SELECT CONVERT(varchar(100), GETDATE(), 20): 2006-05-16 10:57:47
- SELECT CONVERT(varchar(100), GETDATE(), 21): 2006-05-16 10:57:47.157
- SELECT CONVERT(varchar(100), GETDATE(), 22): 05/16/06 10:57:47 AM
- SELECT CONVERT(varchar(100), GETDATE(), 23): 2006-05-16
- SELECT CONVERT(varchar(100), GETDATE(), 24): 10:57:47
- SELECT CONVERT(varchar(100), GETDATE(), 25): 2006-05-16 10:57:47.250
- SELECT CONVERT(varchar(100), GETDATE(), 100): 05 16 2006 10:57AM
- SELECT CONVERT(varchar(100), GETDATE(), 101): 05/16/2006
- SELECT CONVERT(varchar(100), GETDATE(), 102): 2006.05.16
- SELECT CONVERT(varchar(100), GETDATE(), 103): 16/05/2006
- SELECT CONVERT(varchar(100), GETDATE(), 104): 16.05.2006
- SELECT CONVERT(varchar(100), GETDATE(), 105): 16-05-2006
- SELECT CONVERT(varchar(100), GETDATE(), 106): 16 05 2006
- SELECT CONVERT(varchar(100), GETDATE(), 107): 05 16, 2006
- SELECT CONVERT(varchar(100), GETDATE(), 108): 10:57:49
- SELECT CONVERT(varchar(100), GETDATE(), 109): 05 16 2006 10:57:49:437AM
- SELECT CONVERT(varchar(100), GETDATE(), 110): 05-16-2006
- SELECT CONVERT(varchar(100), GETDATE(), 111): 2006/05/16
- SELECT CONVERT(varchar(100), GETDATE(), 112): 20060516
- SELECT CONVERT(varchar(100), GETDATE(), 113): 16 05 2006 10:57:49:513
- SELECT CONVERT(varchar(100), GETDATE(), 114): 10:57:49:547
- SELECT CONVERT(varchar(100), GETDATE(), 120): 2006-05-16 10:57:49
- SELECT CONVERT(varchar(100), GETDATE(), 121): 2006-05-16 10:57:49.700
- SELECT CONVERT(varchar(100), GETDATE(), 126): 2006-05-16T10:57:49.827
- SELECT CONVERT(varchar(100), GETDATE(), 130): 18 ???? ?????? 1427 10:57:49:907AM
- SELECT CONVERT(varchar(100), GETDATE(), 131): 18/04/1427 10:57:49:920AM
复制代码
自增长idmysql id int auto_increment primary key not null
sqlserver id int identity(1,1) primary key not null
oracle(通过序列来实现自增长increment by 1(每次增加量) start with 1(从第几个开始))
- create table users(
- id int primary key not null,
- name varchar(50)
- );
- create sequence users_id increment by 1 start with 1 maxvalue 9999;
- 使用时:
- insert into users(users_id.nextval,'whiteme');
复制代码
作者: fteair 时间: 2020-6-10 14:33
作者: fteair 时间: 2020-6-10 14:34
作者: 张兴康 时间: 2020-6-10 15:12
作者: caixuqad 时间: 2020-6-10 18:21
作者: fteair 时间: 2020-6-11 14:22
作者: fteair 时间: 2020-6-11 14:23
作者: 张兴康 时间: 2020-6-11 15:03
下次整个回帖奖励赛
作者: fteair 时间: 2020-6-14 14:48
作者: 张兴康 时间: 2020-6-14 15:10
作者: caixuqad 时间: 2020-6-14 17:19
作者: caixuqad 时间: 2020-6-15 17:15
欢迎光临 度量快速开发平台-专业、快速的软件定制快开平台 (http://bbs.delit.cn/) |
Powered by Discuz! X3.2 |