项目中常见数据库知识

  最近在写一些接口,总结一下目前想到的一些需要注意的点,说的并不是sqlserver与其他数据库语句的区别,只是想到了就写下来了,老规矩之后想到了在添加进去

分页

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

自增长id

mysql     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');

 

posted @ 2017-08-10 10:15  whiteme  阅读(705)  评论(0编辑  收藏  举报