實用SQL語句大全

由於找不到原做者,因此在這裏只好再次發表了,若是原做者看到,還請見諒。


這個東西總結的真好,很實用,也很全面,但願能給你們帶來幫助。


 


1、基礎


一、說明:建立數據庫 CREATE DATABASE database-name 
二、說明:刪除數據庫 drop database dbname 三、說明:備份sql server --- 建立 備份數據的 device USE master EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' --- 開始 備份 BACKUP DATABASE pubs TO testBack四、說明:建立新表 create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)


根據已有的表建立新表:  sql

A:create table tab_new like tab_old (使用舊錶建立新表)  數據庫

B:create table tab_new as select col1,col2… from tab_old definition only  服務器

五、說明:刪除新表 drop table tabname  ide

六、說明:增長一個列 Alter table tabname add column col type 注:列增長後將不能刪除。DB2中列加上後數據類型也不能改變,惟一能改變的是增長varchar類型的長度。  函數

七、說明:添加主鍵: Alter table tabname add primary key(col) 說明:刪除主鍵: Alter table tabname drop primary key(col)  oop

八、說明:建立索引:create [unique] index idxname on tabname(col….) 刪除索引:drop index idxname 注:索引是不可更改的,想更改必須刪除從新建。  fetch

九、說明:建立視圖:create view viewname as select statement 刪除視圖:drop view viewname  ui

十、說明:幾個簡單的基本的sql語句  加密

選擇:select * from table1 where 範圍  spa

插入:insert into table1(field1,field2) values(value1,value2) 

刪除:delete from table1 where 

範圍 更新:update table1 set field1=value1 where 

範圍 查找:select * from table1 where field1 like ’%value1%’ ---like的語法很精妙,查資料! 

排序:select * from table1 order by field1,field2 [desc] 

總數:select count as totalcount from table1 

求和:select sum(field1) as sumvalue from table1 

平均:select avg(field1) as avgvalue from table1 

最大:select max(field1) as maxvalue from table1 

最小:select min(field1) as minvalue from table1 十一、

說明:幾個高級查詢運算詞
A: UNION 運算符 union UNION 運算符經過組合其餘兩個結果表(例如 TABLE1 和 TABLE2)並消去表中任何重複行而派生出一個結果表。當 ALL 隨 UNION 一塊兒使用時(即 UNION ALL),不消除重複行。兩種狀況下,派生表的每一行不是來自 TABLE1 就是來自 TABLE2。
B: EXCEPT 運算符 except EXCEPT 運算符經過包括全部在 TABLE1 中但不在 TABLE2 中的行並消除全部重複行而派生出一個結果表。當 ALL 隨 EXCEPT 一塊兒使用時 (EXCEPT ALL),不消除重複行。
C: INTERSECT 運算符intersect INTERSECT 運算符經過只包括 TABLE1 和 TABLE2 中都有的行並消除全部重複行而派生出一個結果表。當 ALL 隨 INTERSECT 一塊兒使用時 (INTERSECT ALL),不消除重複行。 

注:使用運算詞的幾個查詢結果行必須是一致的。 

十二、說明:使用外鏈接
A、left (outer) join: 左外鏈接(左鏈接):結果集幾包括鏈接表的匹配行,也包括左鏈接表的全部行。 SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
B:right (outer) join: 右外鏈接(右鏈接):結果集既包括鏈接表的匹配鏈接行,也包括右鏈接表的全部行。
C:full/cross (outer) join: 

全外鏈接:不只包括符號鏈接表的匹配行,還包括兩個鏈接表中的全部記錄。

 十二、分組:Group by:    一張表,一旦分組 完成後,查詢後只能獲得組相關的信息。     
組相關的信息:(統計信息) count,sum,max,min,avg 分組的標準)    
在SQLServer中分組時:不能以text,ntext,image類型的字段做爲分組依據    
在selecte統計函數中的字段,不能和普通的字段放在一塊兒;



1三、對數據庫進行操做:    

分離數據庫: sp_detach_db;
附加數據庫:sp_attach_db 後接代表,附加須要完整的路徑名 

14.如何修改數據庫的名稱: sp_renamedb 'old_name', 'new_name' 



 


2、提高


一、說明:複製表(只複製結構,源表名:a 新表名:b) (Access可用) 法一:select * into b from a where 1<>1(僅用於SQlServer) 法二:select top 0 * into b from a 二、說明:拷貝表(拷貝數據,源表名:a 目標表名:b) (Access可用) insert into b(a, b, c) select d,e,f from b;


三、說明:跨數據庫之間表的拷貝(具體數據使用絕對路徑) (Access可用) insert into b(a, b, c) select d,e,f from b in ‘具體數據庫’ where 條件 例子:..from b in '"&Server.MapPath(".")&"\data.mdb" &"' where..


四、說明:子查詢(表名1:a 表名2:b) select a,b,c from a where a IN (select d from b ) 或者: select a,b,c from a where a IN (1,2,3)


五、說明:顯示文章、提交人和最後回覆時間 select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b


六、說明:外鏈接查詢(表名1:a 表名2:b) select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c


七、說明:在線視圖查詢(表名1:a ) select * from (SELECT a,b,c FROM a) T where t.a > 1;


八、說明:between的用法,between限制查詢數據範圍時包括了邊界值,not between不包括 select * from table1 where time between time1 and time2 select a,b,c, from table1 where a not between 數值1 and 數值2


九、說明:in 的使用方法 select * from table1 where a [not] in (‘值1’,’值2’,’值4’,’值6’)


十、說明:兩張關聯表,刪除主表中已經在副表中沒有的信息 delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 )


十一、說明:四表聯查問題: select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where .....


十二、說明:日程安排提早五分鐘提醒 SQL: select * from 日程安排 where datediff('minute',f開始時間,getdate())>5


1三、說明:一條sql 語句搞定數據庫分頁select top 10 b.* from (select top 20 主鍵字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主鍵字段 = a.主鍵字段 order by a.排序字段 具體實現: 關於數據庫分頁:


  declare @start int, @end int 


  @sql  nvarchar(600)


  set @sql=’select top’+str(@end-@start+1)+’+from T where rid not in(select top’+str(@str-1)+’Rid from T where Rid>-1)’


  exec sp_executesql @sql


注意:在top後不能直接跟一個變量,因此在實際應用中只有這樣的進行特殊的處理。Rid爲一個標識列,若是top後還有具體的字段,這樣作是很是有好處的。由於這樣能夠避免top的字段若是是邏輯索引的,查詢的結果後實際表中的不一致(邏輯索引中的數據有可能和數據表中的不一致,而查詢時若是處在索引則首先查詢索引)


1四、說明:前10條記錄 select top 10 * form table1 where 範圍


1五、說明:選擇在每一組b值相同的數據中對應的a最大的記錄的全部信息(相似這樣的用法能夠用於論壇每個月排行榜,每個月熱銷產品分析,按科目成績排名,等等.) select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b)


1六、說明:包括全部在 TableA 中但不在 TableB和TableC 中的行並消除全部重複行而派生出一個結果表 (select a from tableA ) except (select a from tableB) except (select a from tableC)


1七、說明:隨機取出10條數據 select top 10 * from tablename order by newid()


1八、說明:隨機選擇記錄 select newid()


1九、說明:刪除重複記錄 1),delete from tablename where id not in (select max(id) from tablename group by col1,col2,...) 2),select distinct * into temp from tablename   delete from tablename   insert into tablename select * from temp 評價: 這種操做牽連大量的數據的移動,這種作法不適合大容量但數據操做 3),例如:在一個外部表中導入數據,因爲某些緣由第一次只導入了一部分,但很難判斷具體位置,這樣只有在下一次所有導入,這樣也就產生好多重複的字段,怎樣刪除重複字段


alter table tablename --添加一個自增列 add  column_b int identity(1,1) delete from tablename where column_b not in( select max(column_b)  from tablename group by column1,column2,...) alter table tablename drop column column_b


20、說明:列出數據庫裏全部的表名 select name from sysobjects where type='U' // U表明用戶


2一、說明:列出表裏的全部的列名 select name from syscolumns where id=object_id('TableName')


2二、說明:列示type、vender、pcs字段,以type字段排列,case能夠方便地實現多重選擇,相似select 中的case。 select type,sum(case vender when 'A' then pcs else 0 end),sum(case vender when 'C' then pcs else 0 end),sum(case vender when 'B' then pcs else 0 end) FROM tablename group by type 顯示結果: type vender pcs 電腦 A 1 電腦 A 1 光盤 B 2 光盤 A 2 手機 B 3 手機 C 3


2三、說明:初始化表table1


TRUNCATE TABLE table1


2四、說明:選擇從10到15的記錄 select top 5 * from (select top 15 * from table order by id asc) table_別名 order by id desc


3、技巧


一、1=1,1=2的使用,在SQL語句組合時用的較多


「where 1=1」 是表示選擇所有    「where 1=2」所有不選, 如: if @strWhere !='' begin set @strSQL = 'select count(*) as Total from [' + @tblName + '] where ' + @strWhere end else begin set @strSQL = 'select count(*) as Total from [' + @tblName + ']' end 


咱們能夠直接寫成


錯誤!未找到目錄項。 set @strSQL = 'select count(*) as Total from [' + @tblName + '] where 1=1 安定 '+ @strWhere 二、收縮數據庫 --重建索引 DBCC REINDEX DBCC INDEXDEFRAG --收縮數據和日誌 DBCC SHRINKDB DBCC SHRINKFILE


三、壓縮數據庫 dbcc shrinkdatabase(dbname)


四、轉移數據庫給新用戶以已存在用戶權限 exec sp_change_users_login 'update_one','newname','oldname' go


五、檢查備份集 RESTORE VERIFYONLY from disk='E:\dvbbs.bak'


六、修復數據庫 ALTER DATABASE [dvbbs] SET SINGLE_USER GO DBCC CHECKDB('dvbbs',repair_allow_data_loss) WITH TABLOCK GO ALTER DATABASE [dvbbs] SET MULTI_USER GO


七、日誌清除 SET NOCOUNT ON DECLARE @LogicalFileName sysname, @MaxMinutes INT, @NewSize INT


USE tablename -- 要操做的數據庫名 SELECT  @LogicalFileName = 'tablename_log', -- 日誌文件名 @MaxMinutes = 10, -- Limit on time allowed to wrap log. @NewSize = 1  -- 你想設定的日誌文件的大小(M)


Setup / initialize DECLARE @OriginalSize int SELECT @OriginalSize = size FROM sysfiles WHERE name = @LogicalFileName SELECT 'Original Size of ' + db_name() + ' LOG is ' + CONVERT(VARCHAR(30),@OriginalSize) + ' 8K pages or ' + CONVERT(VARCHAR(30),(@OriginalSize*8/1024)) + 'MB' FROM sysfiles WHERE name = @LogicalFileName CREATE TABLE DummyTrans (DummyColumn char (8000) not null)


DECLARE @Counter    INT, @StartTime DATETIME, @TruncLog   VARCHAR(255) SELECT @StartTime = GETDATE(), @TruncLog = 'BACKUP LOG ' + db_name() + ' WITH TRUNCATE_ONLY'


DBCC SHRINKFILE (@LogicalFileName, @NewSize) EXEC (@TruncLog) -- Wrap the log if necessary. WHILE @MaxMinutes > DATEDIFF (mi, @StartTime, GETDATE()) -- time has not expired AND @OriginalSize = (SELECT size FROM sysfiles WHERE name = @LogicalFileName)  AND (@OriginalSize * 8 /1024) > @NewSize  BEGIN -- Outer loop. SELECT @Counter = 0 WHILE   ((@Counter < @OriginalSize / 16) AND (@Counter < 50000)) BEGIN -- update INSERT DummyTrans VALUES ('Fill Log') DELETE DummyTrans SELECT @Counter = @Counter + 1 END EXEC (@TruncLog)  END SELECT 'Final Size of ' + db_name() + ' LOG is ' + CONVERT(VARCHAR(30),size) + ' 8K pages or ' + CONVERT(VARCHAR(30),(size*8/1024)) + 'MB' FROM sysfiles 
WHERE name = @LogicalFileName DROP TABLE DummyTrans SET NOCOUNT OFF 


八、說明:更改某個表 exec sp_changeobjectowner 'tablename','dbo'


九、存儲更改所有表


CREATE PROCEDURE dbo.User_ChangeObjectOwnerBatch @OldOwner as NVARCHAR(128), @NewOwner as NVARCHAR(128) AS

DECLARE @Name    as NVARCHAR(128) DECLARE @Owner   as NVARCHAR(128) DECLARE @OwnerName   as NVARCHAR(128)

DECLARE curObject CURSOR FOR select 'Name'    = name,    'Owner'    = user_name(uid) from sysobjects where user_name(uid)=@OldOwner order by name

OPEN   curObject FETCH NEXT FROM curObject INTO @Name, @Owner WHILE(@@FETCH_STATUS=0) BEGIN     if @Owner=@OldOwner 
begin    set @OwnerName = @OldOwner + '.' + rtrim(@Name)    exec sp_changeobjectowner @OwnerName, @NewOwner end -- select @name,@NewOwner,@OldOwner

FETCH NEXT FROM curObject INTO @Name, @Owner END

close curObject deallocate curObject GO



數據開發-經典


1.按姓氏筆畫排序: Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as //從少到多


2.數據庫加密:select encrypt('原始密碼') select pwdencrypt('原始密碼') select pwdcompare('原始密碼','加密後密碼') = 1--相同;不然不相同 encrypt('原始密碼') select pwdencrypt('原始密碼') select pwdcompare('原始密碼','加密後密碼') = 1--相同;不然不相同


3.取回表中字段: declare @list varchar(1000), @sql nvarchar(1000) 
select @list=@list+','+b.name from sysobjects a,syscolumns b where a.id=b.id and a.name='表A' set @sql='select '+right(@list,len(@list)-1)+' from 表A' 
exec (@sql)


4.查看硬盤分區: EXEC master..xp_fixeddrives


5.比較A,B表是否相等: if (select checksum_agg(binary_checksum(*)) from A)      =     (select checksum_agg(binary_checksum(*)) from B) print '相等' else print '不相等'


6.殺掉全部的事件探察器進程: DECLARE hcforeach CURSOR GLOBAL FOR SELECT 'kill '+RTRIM(spid) FROM master.dbo.sysprocesses WHERE program_name IN('SQL profiler',N'SQL 事件探查器') EXEC sp_msforeach_worker '?'


7.記錄搜索: 開頭到N條記錄
Select Top N * From 表 ------------------------------- 
N到M條記錄(要有主索引ID) Select Top M-N * From 表 Where ID in (Select Top M ID From 表) Order by ID   Desc
N到結尾記錄Select Top N * From 表 Order by ID Desc 

案例 例如1:一張表有一萬多條記錄,表的第一個字段 RecID 是自增加字段, 寫一個SQL語句, 找出表的第31到第40個記錄。
select top 10 recid from A where recid not  in(select top 30 recid from A)

分析:若是這樣寫會產生某些問題,若是recid在表中存在邏輯索引。
select top 10 recid from A where……是從索引中查找,然後面的select top 30 recid from A則在數據表中查找,這樣因爲索引中的順序有可能和數據表中的不一致,這樣就致使查詢到的不是原本的欲獲得的數據。


解決方案
1, 用order by select top 30 recid from A order by ricid 若是該字段不是自增加,就會出現問題
2, 在那個子查詢中也加條件:select top 30 recid from A where recid>-1


例2:查詢表中的最後以條記錄,並不知道這個表共有多少數據,以及表結構。 set @s = 'select top 1 * from T   where pid not in (select top ' + str(@count-1) + ' pid  from  T)'
print @s      exec  sp_executesql  @s


9:獲取當前數據庫中的全部用戶表

select Name from sysobjects where xtype='u' and status>=0



10:獲取某一個表的全部字段

select name from syscolumns where id=object_id('表名')
select name from syscolumns where id in (select id from sysobjects where type = 'u' and name = '表名')
兩種方式的效果相同



11:查看與某一個表相關的視圖、存儲過程、函數select a.* from sysobjects a, syscomments b where a.id = b.id and b.text like '%表名%'


12:查看當前數據庫中全部存儲過程 select name as 存儲過程名稱 from sysobjects where xtype='P'


13:查詢用戶建立的全部數據庫 select * from master..sysdatabases D where sid not in(select sid from master..syslogins where name='sa') 或者 select dbid, name AS DB_NAME from master..sysdatabases where sid <> 0x01


14:查詢某一個表的字段和數據類型 select column_name,data_type from information_schema.columns where table_name = '表名' 


15:不一樣服務器數據庫之間的數據操做


--建立連接服務器 

exec sp_addlinkedserver   'ITSV ', ' ', 'SQLOLEDB ', '遠程服務器名或ip地址 ' 
exec sp_addlinkedsrvlogin  'ITSV ', 'false ',null, '用戶名 ', '密碼 ' 


--查詢示例 
select * from ITSV.數據庫名.dbo.表名 


--導入示例 
select * into 表 from ITSV.數據庫名.dbo.表名 


--之後再也不使用時刪除連接服務器 
exec sp_dropserver  'ITSV ', 'droplogins ' 



--鏈接遠程/局域網數據(openrowset/openquery/opendatasource) 


--一、openrowset 

--查詢示例 
select * from openrowset( 'SQLOLEDB ', 'sql服務器名 '; '用戶名 '; '密碼 ',數據庫名.dbo.表名) 


--生成本地表 
select * into 表 from openrowset( 'SQLOLEDB ', 'sql服務器名 '; '用戶名 '; '密碼 ',數據庫名.dbo.表名) 


--把本地表導入遠程表 
insert openrowset( 'SQLOLEDB ', 'sql服務器名 '; '用戶名 '; '密碼 ',數據庫名.dbo.表名) select *from 本地表 


--更新本地表 
update b set b.列A=a.列A from openrowset( 'SQLOLEDB ', 'sql服務器名 '; '用戶名 '; '密碼 ',數據庫名.dbo.表名)as a inner join 本地表 b  on a.column1=b.column1 


--openquery用法須要建立一個鏈接 

--首先建立一個鏈接建立連接服務器 
exec sp_addlinkedserver   'ITSV ', ' ', 'SQLOLEDB ', '遠程服務器名或ip地址 ' 


--查詢 
select * FROM openquery(ITSV,  'SELECT *  FROM 數據庫.dbo.表名 ') 


--把本地表導入遠程表 
insert openquery(ITSV,  'SELECT *  FROM 數據庫.dbo.表名 ') select * from 本地表 


--更新本地表 
update b set b.列B=a.列B FROM openquery(ITSV,  'SELECT * FROM 數據庫.dbo.表名 ') as a  inner join 本地表 b on a.列A=b.列A 


--三、opendatasource/openrowset 
SELECT   * FROM   opendatasource( 'SQLOLEDB ',  'Data Source=ip/ServerName;User ID=登錄名;Password=密碼 ' ).test.dbo.roy_ta 


--把本地表導入遠程表 
insert opendatasource( 'SQLOLEDB ',  'Data Source=ip/ServerName;User ID=登錄名;Password=密碼 ').數據庫.dbo.表名  select * from 本地表  


--更新修改過的數據 update b set name=i.name,telphone=i.telphone from srv2.庫名.dbo.author b,author i where b.id=i.id and(b.name <> i.name or b.telphone <> i.telphone)  

--插入新增的數據 insert srv2.庫名.dbo.author(id,name,telphone) select id,name,telphone from author i where not exists( select * from srv2.庫名.dbo.author where id=i.id)  

--刪除已經刪除的數據(若是須要的話) delete b from srv2.庫名.dbo.author b where not exists( select * from author where id=b.id)go

--SQL Server: Select TOP N * From TABLE Order By NewID() 
--Access: Select TOP N * From TABLE Order By Rnd(ID)  Rnd(ID) 其中的ID是自動編號字段,能夠利用其餘任何數值來完成,好比用姓名字段(UserName) Select TOP N *  From TABLE Order BY Rnd(Len(UserName)) 
--MySql: Select * From TABLE Order By Rand() Limit 10  
--開頭到N條記錄 Select Top N * From 表
--N到M條記錄(要有主索引ID) Select Top M-N * From 表Where ID in (Select Top M ID From 表) Order by ID  Desc
--選擇10從到15的記錄 select top 5 * from (select top 15 * from table order by id asc) table_別名order by id desc 
--N到結尾記錄 Select Top N * From 表Order by ID Desc 


 


--顯示最後5條記錄,可是顯示的順序必須爲5,6,7,8,9,10,而不是10,9,8,7,6,5 以下解決方法:
select top 5 from test where id in(select top 5 from test order by id desc) order by id asc 


--經過這個問題也能總結出4-10條,5-100條這種限定必定範圍內的sql語句的寫法:
select top <末端ID-頂端ID+1> * from <表名> where ID not in(select top <頂端ID-1>) ID from <表名>)
--例如:4-10條就應該寫成 select top 10-4+1 * from test where id not in(select top 4-1 id from test)


 


 上一篇: select top 1 * from [news_table] where [新聞標識列]<當前id號 where ...... 下一篇: select top 1 * from [news_table] where [新聞標識列]>當前id號 where ...... order by [新聞標識列] desc 


一個表中的Id有多個記錄,把全部這個id的記錄查出來,並顯示共有多少條記錄數。 ------------------------------------------ select id, Count(*) from tb group by id having count(*)>1
 --兩條記錄徹底相同,如何刪除其中一條 set rowcount=1 delete from thetablename where id=@duplicate_id--@duplicate_id爲重複值的id 
--模糊查詢 select *  from product where detail like '%123.jpg%' --替換字段裏面部份內容 update product set detail=replace(cast(detail as varchar(8000)),'abc.jpg','efg.jpg') 


--日期轉換參數,值得收藏 select CONVERT(varchar, getdate(), 120 ) 2004-09-12 11:06:08 
select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),'-',''),' ',''),':','') 20040912110608
select CONVERT(varchar(12) , getdate(), 111 ) 2004/09/12
select CONVERT(varchar(12) , getdate(), 112 ) 20040912
select CONVERT(varchar(12) , getdate(), 102 ) 2004.09.12
 
--一個月第一天 SELECT   DATEADD(mm,   DATEDIFF(mm,0,getdate()),   0)  --  2009-06-01 00:00:00.000
--當天 select  * from product  where DateDiff(day,modiDate,GetDate())>1 
--如何查詢本日、本月、本年的記錄SQL 本年: select * from loanInfo where year(date)=year(getdate()) 本月: select * from loanInfo where year(date)=year(getDate()) And month(date)=month(getdate()) 本日: select * from loanInfo where year(date)=year(getDate()) And month(date)=month(getdate()) and Day(date)=Day(getDate())   
本週的星期一   SELECT  DATEADD(wk,  DATEDIFF(wk,0,getdate()),  0)  一年的第一天  SELECT  DATEADD(yy,  DATEDIFF(yy,0,getdate()),  0)  季度的第一天   SELECT  DATEADD(qq,  DATEDIFF(qq,0,getdate()),  0)  當天的半夜   SELECT  DATEADD(dd,  DATEDIFF(dd,0,getdate()),  0)  上個月的最後一天        這是一個計算上個月最後一天的例子。它經過從一個月的最後一天這個例子上減去毫秒來得到。有一點要記住,在Sql  Server中時間是精確到毫秒。這就是爲何我須要減去毫秒來得到我要的日期和時間。        SELECT  dateadd(ms,-3,DATEADD(mm,  DATEDIFF(mm,0,getdate()),  0))         計算出來的日期的時間部分包含了一個Sql  Server能夠記錄的一天的最後時刻(「:59:59:997」)的時間。 去年的最後一天        鏈接上面的例子,爲了要獲得去年的最後一天,你須要在今年的第一天上減去毫秒。        SELECT  dateadd(ms,-3,DATEADD(yy,  DATEDIFF(yy,0,getdate()),  0))  本月的最後一天        如今,爲了得到本月的最後一天,我須要稍微修改一下得到上個月的最後一天的語句。修改須要給用DATEDIFF比較當前日期和「-01-01」返回的時間間隔上加。經過加個月,我計算出下個月的第一天,而後減去毫秒,這樣就計算出了這個月的最後一天。這是計算本月最後一天的SQL腳本。        SELECT  dateadd(ms,-3,DATEADD(mm,  DATEDIFF(m,0,getdate())+1,  0))  本年的最後一天        你如今應該掌握這個的作法,這是計算本年最後一天腳本        SELECT  dateadd(ms,-3,DATEADD(yy,  DATEDIFF(yy,0,getdate())+1,  0))。 本月的第一個星期一        好了,如今是最後一個例子。這裏我要計算這個月的第一個星期一。這是計算的腳本。          select  DATEADD(wk,  DATEDIFF(wk,0,                                                                                         dateadd(dd,6-datepart(day,getdate()),getdate())                                                                                                         ),  0)                                 在這個例子裏,我使用了「本週的星期一」的腳本,並做了一點點修改。修改的部分是把原來腳本中「getdate()」部分替換成計算本月的第天,在計算中用本月的第天來替換當前日期使得計算能夠得到這個月的第一個星期一。 
--刪除一個月前,三個月前, 6個月前,一年前的數據 
DELETE FROM 表名WHERE datediff(MM, AddTime,GETDATE()) > 1 DELETE FROM 表名WHERE datediff(MM, AddTime,GETDATE()) > 3 DELETE FROM 表名WHERE datediff(MM, AddTime,GETDATE()) > 6 DELETE FROM 表名WHERE datediff(YY, AddTime,GETDATE()) > 1
---------------------------------------------------------------  附錄,其餘日期處理方法 1)去掉時分秒 declare  @  datetime  set  @  =  getdate()  --'2003-7-1  10:00:00'  SELECT  @,DATEADD(day,  DATEDIFF(day,0,@),  0)  2)顯示星期幾 select  datename(weekday,getdate())    3)如何取得某個月的天數 declare  @m  int  set  @m=2  --月份 select    datediff(day,'2003-'+cast(@m  as  varchar)+'-15'  ,'2003-'+cast(@m+1    as  varchar)+'-15')  
另外,取得本月天數 select    datediff(day,cast(month(GetDate())  as  varchar)+'-'+cast(month(GetDate())  as  varchar)+'-15'  ,cast(month(GetDate())  as  varchar)+'-'+cast(month(GetDate())+1    as  varchar)+'-15')  
任意月份的最大天數 select  day(dateadd(dd,-1,dateadd(mm,1,Dateadd(mm,datediff(mm,0,getdate()),0)))) 
或者使用計算本月的最後一天的腳本,而後用DAY函數區最後一天 SELECT  Day(dateadd(ms,-3,DATEADD(mm,  DATEDIFF(m,0,getdate())+1,  0)))  4)判斷是否閏年: 
SELECT  case  day(dateadd(mm,  2,  dateadd(ms,-3,DATEADD(yy,  DATEDIFF(yy,0,getdate()),  0))))  when  28  then  '平年'  else  '閏年'  end  
或者 select  case  datediff(day,datename(year,getdate())+'-02-01',dateadd(mm,1,datename(year,getdate())+'-02-01'))  when  28  then  '平年'  else  '閏年'  end  5)一個季度多少天 declare  @m  tinyint,@time  smalldatetime  select  @m=month(getdate())  select  @m=case  when  @m  between  1  and  3  then  1                         when  @m  between  4  and  6  then  4                         when  @m  between  7  and  9  then  7                         else  10  end  select  @time=datename(year,getdate())+'-'+convert(varchar(10),@m)+'-01'  select  datediff(day,@time,dateadd(mm,3,@time))   


一、肯定某年某月有多少天
實現原理:先利用DATEDIFF取得當前月的第一天,再將月份加一取得下月第一天,而後減去分鐘,再取日期的天數部分,即爲當月最大日期,也即當月天數
CREATE FUNCTION DaysInMonth ( @date datetime ) Returns int AS BEGIN RETURN Day(dateadd(mi,-3,DATEADD(m, DATEDIFF(m,0,@date)+1,0))) END
調用示例:
select dbo.DaysInMonth ('2006-02-03') 
(2)計算哪一天是本週的星期一
SELECT DATEADD(week, DATEDIFF(week,'1900-01-01',getdate()), '1900-01-01')  --返回-11-06 00:00:00.000 或 SELECT DATEADD(week, DATEDIFF(week,0,getdate()),0)      
(3)當前季度的第一天
SELECT DATEADD(quarter, DATEDIFF(quarter,0,getdate()), 0)—返回-10-01 00:00:00.000 
(4)一個季度多少天
declare @m tinyint,@time smalldatetime 
select @m=month(getdate()) select @m=case when @m between 1 and 3 then 1                        when @m between 4 and 6 then 4                        when @m between 7  and 9 then 7                        else 10 end 
select @time=datename(year,getdate())+'-'+convert(varchar(10),@m)+'-01' select datediff(day,@time,dateadd(mm,3,@time)) —返回


 
1.按姓氏筆畫排序: Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as 
2.分頁SQL語句 select * from(select (row_number() OVER (ORDER BY tab.ID Desc)) as rownum,tab.* from 表名As tab) As t where rownum between 起始位置And 結束位置
8.如何修改數據庫的名稱:
sp_renamedb 'old_name', 'new_name' 
3.獲取當前數據庫中的全部用戶表 select * from sysobjects where xtype='U' and category=0 
4.獲取某一個表的全部字段 select name from syscolumns where id=object_id('表名') 
5.查看與某一個表相關的視圖、存儲過程、函數 select a.* from sysobjects a, syscomments b where a.id = b.id and b.text like '%表名%' 
6.查看當前數據庫中全部存儲過程 select name as 存儲過程名稱from sysobjects where xtype='P' 
7.查詢用戶建立的全部數據庫 select * from master..sysdatabases D where sid not in(select sid from master..syslogins where name='sa') 或者 select dbid, name AS DB_NAME from master..sysdatabases where sid <> 0x01 
8.查詢某一個表的字段和數據類型 select column_name,data_type from information_schema.columns where table_name = '表名' 




9.使用事務 在使用一些對數據庫表的臨時的SQL語句操做時,能夠採用SQL SERVER事務處理,防止對數據操做後發現誤操做問題
開始事務 Begin tran Insert Into TableName Values(…) SQL語句操做不正常,則回滾事務。
回滾事務 Rollback tran SQL語句操做正常,則提交事務,數據提交至數據庫。
提交事務 Commit tran 
計算執行SQL語句查詢時間
declare @d datetime set @d=getdate() select * from SYS_ColumnProperties select [語句執行花費時間(毫秒)]=datediff(ms,@d,getdate()) 


【關閉SQL Server 數據庫全部使用鏈接】
use  master go create  proc  KillSpByDbName(@dbname  varchar(20))  as  begin  declare  @sql  nvarchar(500),@temp varchar(1000) declare  @spid  int  set  @sql='declare  getspid  cursor  for    select  spid  from  sysprocesses  where  dbid=db_id('''+@dbname+''')'  exec  (@sql)  open  getspid  fetch  next  from  getspid  into  @spid  while  @@fetch_status <>-1  begin    set @temp='kill  '+rtrim(@spid)   exec(@temp) fetch  next  from  getspid  into  @spid  end  close  getspid  deallocate  getspid  end  
--舉例使用,關閉數據庫下的全部鏈接操做 Use  master  Exec  KillSpByDbName  '數據庫名稱' 
(一)掛起操做 在安裝Sql或sp補丁的時候系統提示以前有掛起的安裝操做,要求重啓,這裏每每重啓無用,解決辦法: 到HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlSession Manager 刪除PendingFileRenameOperations
(二)收縮數據庫 --重建索引 DBCC REINDEX DBCC INDEXDEFRAG --收縮數據和日誌 DBCC SHRINKDB DBCC SHRINKFILE
(三)壓縮數據庫 dbcc shrinkdatabase(dbname)
(四)轉移數據庫給新用戶以已存在用戶權限 exec sp_change_users_login update_one,newname,oldname go
(五)檢查備份集 RESTORE VERIFYONLY from disk=Evbbs.bak
(六)修復數據庫 ALTER DATABASE [dvbbs] SET SINGLE_USER GO DBCC CHECKDB(dvbbs,repair_allow_data_loss) WITH TABLOCK GO ALTER DATABASE [dvbbs] SET MULTI_USER GO
 


select top m * from tablename where id not in (select top n id from tablename) 
select top m * into 臨時表(或表變量) from tablename order by columnname -- 將top m筆插入 set rowcount n select * from 表變量order by columnname desc 
select top n * from (select top m * from tablename order by columnname) a order by columnname desc 
若是tablename裏沒有其餘identity列,那麼: select identity(int) id0,* into #temp from tablename 
取n到m條的語句爲: select * from #temp where id0 >=n and id0 <= m 
若是你在執行select identity(int) id0,* into #temp from tablename這條語句的時候報錯,那是由於你的DB中間的select into/bulkcopy屬性沒有打開要先執行: exec sp_dboption 你的DB名字,'select into/bulkcopy',true 
若是表裏有identity屬性,那麼簡單: select * from tablename where identitycol between n and m 
若是是sql server 2005 能夠這樣寫: select top 20 * from T order col except select top 2 * from T order col 


複製表(只複製結構,源表名:a 新表名:b) (Access可用) 法一:select * into b from a where 1 <>1法二:select top 0 * into b from a 
拷貝表(拷貝數據,源表名:a 目標表名:b) (Access可用) insert into b(a, b, c) select d,e,f from b; 
跨數據庫之間表的拷貝(具體數據使用絕對路徑) (Access可用) insert into b(a, b, c) select d,e,f from b in ‘具體數據庫’where 條件 例子:..from b in '"&Server.MapPath(".")&"\data.mdb" &"' where.. 
子查詢(表名:a 表名:b) select a,b,c from a where a IN (select d from b ) 或者: select a,b,c from a where a IN (1,2,3) 
顯示文章、提交人和最後回覆時間 select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b 
外鏈接查詢(表名:a 表名:b) select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c 
在線視圖查詢(表名:a ) select * from (SELECT a,b,c FROM a) T where t.a > 1; 
between的用法,between限制查詢數據範圍時包括了邊界值,not between不包括 select * from table1 where time between time1 and time2 select a,b,c, from table1 where a not between 數值and 數值
in 的使用方法 select * from table1 where a [not] in (‘值’,’值’,’值’,’值’) 
兩張關聯表,刪除主表中已經在副表中沒有的信息 delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 ) 
四表聯查問題: select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where .. 
日程安排提早五分鐘提醒 SQL: select * from 日程安排where datediff('minute',f開始時間,getdate())>5 
一條sql 語句搞定數據庫分頁 select top 10 b.* from (select top 20 主鍵字段,排序字段from 表名order by 排序字段desc) a,表名b where b.主鍵字段= a.主鍵字段order by a.排序字段
 選擇在每一組b值相同的數據中對應的a最大的記錄的全部信息(相似這樣的用法能夠用於論壇每個月排行榜,每個月熱銷產品分析,按科目成績排名,等等.) select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b) 
包括全部在TableA 中但不在TableB和TableC 中的行並消除全部重複行而派生出一個結果表 (select a from tableA ) except (select a from tableB) except (select a from tableC) 
隨機取出條數據

select top 10 * from tablename order by newid() 

隨機選擇記錄

select newid() 

刪除重複記錄

Delete from tablename where id not in (select max(id) from tablename group by col1,col2,) 
select distinct * into #Tmp from TB drop table TB select * into TB from #Tmp drop table #Tmp

 
列出數據庫裏全部的表名

select name from sysobjects where type='U' 

列出表裏的全部的

select name from syscolumns where id=object_id('TableName') 

列示type、vender、pcs字段,以type字段排列,case能夠方便地實現多重選擇,相似select 中的case。 

select type,sum(case vender when 'A' then pcs else 0 end),sum(case vender when 'C' then pcs else 0 end),sum(case vender when 'B' then pcs else 0 end) FROM tablename group by type
顯示結果: type vender pcs 電腦A 1電腦A 1光盤B 2光盤A 2手機B 3手機C 3 





複製表結構,而不復制內容
select * into #table1 from admin where 1 <>1 --不會複製數據
select * from #table1 
drop table #table1 
這樣#table1就有了admin 的全部字段了


比較A,B表是否相等:

 if(select checksum_agg(binary_checksum(*)) from A)=(select checksum_agg(binary_checksum(*)) from B) print '相等' else print '不相等'



float字段保留一位小數,四捨五入 SELECT CONVERT(DECIMAL(18,1),1024.791454) ------- 1024.8 (所影響的行數爲1 行) <%# Eval("字段")==null?"":Eval("字段").toString("0.0") %>
相關文章
相關標籤/搜索