最近在寫一些介面,總結一下目前想到的一些需要註意的點,說的並不是sqlserver與其他資料庫語句的區別,只是想到了就寫下來了,老規矩之後想到了在添加進去 分頁 sqlserver sqlserver一般通過not in/row_number()(不支持limit)一共兩種,網上還有一種是要在201 ...
最近在寫一些介面,總結一下目前想到的一些需要註意的點,說的並不是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');