• 项目中常见数据库知识


      最近在写一些接口,总结一下目前想到的一些需要注意的点,说的并不是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');

     

  • 相关阅读:
    您还在用下一步下一步的方式安装SQLSERVER和SQLSERVER补丁吗?
    SQLSERVER误删除了Windows登录用户验证方式使用Windows身份验证的解决方法
    批量解密SQLSERVER数据库中的各种对象的工具dbForge SQL Decryptor
    SQLSERVER将数据移到另一个文件组之后清空文件组并删除文件组
    SQLSERVER群集故障转移笔记
    兼容,原来在这里就已经開始--------Day34
    Objective-C的对象模型和runtime机制
    CF B. Kolya and Tandem Repeat
    循环队列的实现
    LintCode 子树
  • 原文地址:https://www.cnblogs.com/whiteme/p/7337778.html
Copyright © 2020-2023  润新知