社区应用 最新帖子 精华区 社区服务 会员列表 统计排行 社区论坛任务 迷你宠物
  • 5125阅读
  • 0回复

[转贴]精妙SQL语句收集

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

SQL语句先前写的时候,很容易把一些特殊的用法忘记,我特此整理了一下SQL语句操作。 e5MX5 T^  
|',MgA  
P.LMu  
一、基础 #p0vrQ;5f  
1、说明:创建数据库 !5pnl0DK*  
CREATE DATABASE database-name -$t#AYKz  
2、说明:删除数据库 Rs7=v2>I  
drop database dbname F $B _;G  
3、说明:备份sql server 7?e*b(vd  
--- 创建 备份数据的 device 5_{C \S`T  
USE master 98G>I(Cw%  
EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' DjtUX>e  
--- 开始 备份 W$  M4#  
BACKUP DATABASE pubs TO testBack GJU84Xn7  
4、说明:创建新表 lkOugjI  
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..) tyNT1F{  
根据已有的表创建新表: 9tWu>keu  
A:create table tab_new like tab_old (使用旧表创建新表) u1(`^^Ml  
B:create table tab_new as select col1,col2... from tab_old definition only Q % )fuI  
5、说明:删除新表 u05Zg*.[  
drop table tabname t*~V]wZ  
6、说明:增加一个列 dk# LAm0<  
Alter table tabname add column col type gm\P`~+o  
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。 _|`S9Nms  
7、说明:添加主键: Alter table tabname add primary key(col) "}Vow^vb  
说明:删除主键: Alter table tabname drop primary key(col) ):31!IC  
8、说明:创建索引:create [unique] index idxname on tabname(col....) C65( m  
删除索引:drop index idxname 7NE"+EP\{2  
注:索引是不可更改的,想更改必须删除重新建。 4DaLmQ2O  
9、说明:创建视图:create view viewname as select statement p~6/  
删除视图:drop view viewname Z~CL|=  
10、说明:几个简单的基本的sql语句 e3}`]  
选择:select * from table1 where 范围 p<: bP w  
插入:insert into table1(field1,field2) values(value1,value2) Gk g)\ 3  
删除:delete from table1 where 范围 N*gnwrP{  
更新:update table1 set field1=value1 where 范围 7='lu;=,  
查找:select * from table1 where field1 like '%value1%' ---like的语法很精妙,查资料! +:+q,0~*]  
排序:select * from table1 order by field1,field2 [desc] ^9UKsy/q  
总数:select count as totalcount from table1 HM /2/ /  
求和:select sum(field1) as sumvalue from table1 DKp+ nq$  
平均:select avg(field1) as avgvalue from table1 >hQeu1 ~W  
最大:select max(field1) as maxvalue from table1 S=@.<gS  
最小:select min(field1) as minvalue from table1 yyW;VKN  
9(V12gn+lk  
wsYvbI!  
]yiwdQ  
11、说明:几个高级查询运算词 2x<,R/}  
;shhg z$  
Bf1,(^3XH  
A: UNION 运算符 % \IB_M  
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。 4}E|CD/pZ  
B: EXCEPT 运算符 2+ m%f"  
EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。 B>hf|.GI  
C: INTERSECT 运算符 50q(8F-N  
INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。 rozp  
注:使用运算词的几个查询结果行必须是一致的。 m-Z<zEQ  
12、说明:使用外连接 4i|yEf  
A、left outer join: f~ kz=R=  
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。 4+"2K-]   
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 wc`UcGO  
B:right outer join: nLicog)!I  
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。 F!(Vg  
C:full outer join: R OsR;C0!  
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。 H]As2$[  
8w /$!9[  
W;!OxOWZJ  
二、提升 wr I66R}@  
1、说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用) uj;tmK>;  
法一:select * into b from a where 1<>1 cBZ$$$v\#  
法二:select top 0 * into b from a pY]T3 2  
2、说明:拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用) 9K,PT.c  
insert into b(a, b, c) select d,e,f from b; kCRfO}wt3  
3、说明:跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用) (d mLEt  
insert into b(a, b, c) select d,e,f from b in '具体数据库' where 条件 A:! _ &  
例子:..from b in '"&Server.MapPath(".")&"\data.mdb" &"' where.. 3Z/_}5%"  
4、说明:子查询(表名1:a 表名2:b) Pfi|RTX$'*  
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) +L(|?|i8  
5、说明:显示文章、提交人和最后回复时间 a|S6r-_;s  
select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b pDqX% $^  
6、说明:外连接查询(表名1:a 表名2:b) DXA<m2&64N  
select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c D y+)s-8  
7、说明:在线视图查询(表名1:a ) n<q1itjD  
select * from (SELECT a,b,c FROM a) T where t.a > 1; d^h`gu~3  
8、说明:between的用法,between限制查询数据范围时包括了边界值,not between不包括 y``[CBj  
select * from table1 where time between time1 and time2 f3PDLQA  
select a,b,c, from table1 where a not between 数值1 and 数值2 Bl[4[N  
9、说明:in 的使用方法  /5M0[C E  
select * from table1 where a [not] in ('值1','值2','值4','值6') %  ]G'u  
10、说明:两张关联表,删除主表中已经在副表中没有的信息 7W[+e&  
delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 ) )<YfLDgTs  
11、说明:四表联查问题: 6.5E d-  
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 ..... v *icoj  
12、说明:日程安排提前五分钟提醒 O?,Grn%'.  
SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5 Pa)'xfQ$Y6  
13、说明:一条sql 语句搞定数据库分页 M18 >%zM  
select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段 -J &y]'  
14、说明:前10条记录 Z:eB9R#2y  
select top 10 * form table1 where 范围 |xYr0C[Pq  
15、说明:选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.) 'aV])(Wm>  
select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b) HE!"3S2S&+  
16、说明:包括所有在 TableA 中但不在 TableB和TableC 中的行并消除所有重复行而派生出一个结果表 0MpZdJ  
(select a from tableA ) except (select a from tableB) except (select a from tableC) =)b!M^=X-a  
17、说明:随机取出10条数据 @~7y\G  
select top 10 * from tablename order by newid() =1#obB  
18、说明:随机选择记录 m4\e `nl  
select newid() R ?62g H  
19、说明:删除重复记录 {:;6 *W  
Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...) c o 8bnH  
20、说明:列出数据库里所有的表名 0nr5(4h  
select name from sysobjects where type='U' nMM:Tr  
21、说明:列出表里的所有的 ~cr##Ff 5  
select name from syscolumns where id=object_id('TableName') iy!SqC  
22、说明:列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。 ]?S@g'Jd0Q  
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 A_8Xhem${  
显示结果: 3ch<a0  
type vender pcs >:J7u*>$'  
电脑 A 1 x&p.-Fi  
电脑 A 1 ]C'^&:&<  
光盘 B 2 <S ae:m4  
光盘 A 2 Tfq7<<0$N  
手机 B 3 +h ]~m_O  
手机 C 3 PPAcEXsIu  
23、说明:初始化表table1 mP*Ct6628n  
TRUNCATE TABLE table1 NI  r"i2  
24、说明:选择从10到15的记录 R E0ud_q2  
select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc d HN"pNNs  
"f~*4g  
D?.H|%  
Y~TD)c=  
三、技巧 '2z1$zst,#  
1、1=1,1=2的使用,在SQL语句组合时用的较多 ^V}c8 P|  
"where 1=1" 是表示选择全部  "where 1=2"全部不选, ]A=yj@o$xN  
如: 8/vGA=  
if @strWhere !='' P+L#p(K  
begin 'vwu^u?  
set @strSQL = 'select count(*) as Total from [' + @tblName + '] where ' + @strWhere y g:&cIr,  
end #_SsSD=.Sy  
else -xXdT$Xd  
begin G)IK5zCDd  
set @strSQL = 'select count(*) as Total from [' + @tblName + ']' V1#:[o63+  
end N&yr?b'!-*  
我们可以直接写成 m)l'i!Y  
set @strSQL = 'select count(*) as Total from [' + @tblName + '] where 1=1 安定 '+ @strWhere :y.~IQN  
2、收缩数据库 Y 'y yrn}  
--重建索引 8|L;y[v  
DBCC REINDEX 7!F -.kG  
DBCC INDEXDEFRAG %63s(ekU  
--收缩数据和日志 [a_'pAH  
DBCC SHRINKDB 5[y+X|Am  
DBCC SHRINKFILE (nu;o!mo9  
3、压缩数据库 u|"y&>!R-  
dbcc shrinkdatabase(dbname) lFtH;h,==v  
4、转移数据库给新用户以已存在用户权限 dI+Y1Vq  
exec sp_change_users_login 'update_one','newname','oldname' _]v@Dq VP  
go @+{F\SD\  
5、检查备份集 oTJ^WePZQ  
RESTORE VERIFYONLY from disk='E:\dvbbs.bak' "c.@4#/_  
6、修复数据库 s^>  >]  
ALTER DATABASE [dvbbs] SET SINGLE_USER WES$B7y  
GO 2kcDJ{(  
DBCC CHECKDB('dvbbs',repair_allow_data_loss) WITH TABLOCK S2jn  pf}  
GO Q7#t#XM  
ALTER DATABASE [dvbbs] SET MULTI_USER dsU'UG7L  
GO o<gK"P  
7、日志清除 fHODS9HQ  
SET NOCOUNT ON + )n}n5  
DECLARE @LogicalFileName sysname, "+M0lGTB  
        @MaxMinutes INT, oFb~|>d  
        @NewSize INT GdYQq.  
USE    tablename            -- 要操作的数据库名 d@%PTSX  
SELECT  @LogicalFileName = 'tablename_log',  -- 日志文件名 <Nk:C1Op}  
@MaxMinutes = 10,              -- Limit on time allowed to wrap log. 3#? 53s   
        @NewSize = 1                  -- 你想设定的日志文件的大小(M) <0!<T+JQ  
-- Setup / initialize ;i?rd f  
DECLARE @OriginalSize int G<-<>)zO!  
SELECT @OriginalSize = size Hqtv`3g  
  FROM sysfiles )(9[>_+40  
  WHERE name = @LogicalFileName Ft^X[5G4L  
SELECT 'Original Size of ' + db_name() + ' LOG is ' + Jcy+(7lE)  
        CONVERT(VARCHAR(30),@OriginalSize) + ' 8K pages or ' +  p9 G{Q  
        CONVERT(VARCHAR(30),(@OriginalSize*8/1024)) + 'MB' #-i#mbZ e  
  FROM sysfiles a/</P |UG  
  WHERE name = @LogicalFileName Y P,>vzW  
CREATE TABLE DummyTrans 6e S~*  
  (DummyColumn char (8000) not null) LJ6L#es2  
DECLARE @Counter  INT, ~/qBOeU3  
        @StartTime DATETIME, 3 a|pk4M  
        @TruncLog  VARCHAR(255) h1H$3TpP  
SELECT  @StartTime = GETDATE(), QHxof7  
        @TruncLog = 'BACKUP LOG ' + db_name() + ' WITH TRUNCATE_ONLY' H$V`,=H  
DBCC SHRINKFILE (@LogicalFileName, @NewSize) dT0>\9ZNr  
EXEC (@TruncLog) j#Qnu0D  
-- Wrap the log if necessary. b<%c ]z  
WHILE    @MaxMinutes > DATEDIFF (mi, @StartTime, GETDATE()) -- time has not expired N!fjN >cw  
      AND @OriginalSize = (SELECT size FROM sysfiles WHERE name = @LogicalFileName)  S17;;w0  
      AND (@OriginalSize * 8 /1024) > @NewSize  9}_'  
  BEGIN -- Outer loop. i;atYltEJ2  
    SELECT @Counter = 0 &e78xtA{  
    WHILE  ((@Counter < @OriginalSize / 16) AND (@Counter < 50000)) X~cdM1z?  
      BEGIN -- update cm0$v8  
        INSERT DummyTrans VALUES ('Fill Log')  AhkDLm+  
        DELETE DummyTrans )PkW,214#  
        SELECT @Counter = @Counter + 1 @?jtB  
      END  ~0h@p4  
    EXEC (@TruncLog)  &=f?:UZ%  
  END  xYZ,.  
SELECT 'Final Size of ' + db_name() + ' LOG is ' + .4ZOm'ko{  
        CONVERT(VARCHAR(30),size) + ' 8K pages or ' + )~Gn7  
        CONVERT(VARCHAR(30),(size*8/1024)) + 'MB' h@z0 x4_])  
  FROM sysfiles %LM6=nt  
  WHERE name = @LogicalFileName L?Ys(a"k  
DROP TABLE DummyTrans 5$$# d_Gj  
SET NOCOUNT OFF CG95ScrX  
8、说明:更改某个表 E0x\h<6W~  
exec sp_changeobjectowner 'tablename','dbo' =XtQ\$Pax  
9、存储更改全部表 ^i r)z@P?V  
CREATE PROCEDURE dbo.User_ChangeObjectOwnerBatch O c.fvP^ZD  
@OldOwner as NVARCHAR(128), N~0ih T G5  
@NewOwner as NVARCHAR(128) za+)2/ `L  
AS G[*z,2Kb>  
DECLARE @Name  as NVARCHAR(128) 7l ,f  
DECLARE @Owner  as NVARCHAR(128) V;W{pd-I  
DECLARE @OwnerName  as NVARCHAR(128) A;^ iy]"  
DECLARE curObject CURSOR FOR oHr0;4Lg6  
select 'Name'  = name, r \[|'hA  
  'Owner'  = user_name(uid) I:HrBhI)wP  
from sysobjects 4AKr.a0q  
where user_name(uid)=@OldOwner =j{tFxJ  
order by name 4l{$dtKbI  
OPEN  curObject )&O6d .  
FETCH NEXT FROM curObject INTO @Name, @Owner Mna yiJl  
WHILE(@@FETCH_STATUS=0) c%WO#}r|  
BEGIN    xXc>YTK'  
if @Owner=@OldOwner ?68~g<d,  
begin icX4n  
  set @OwnerName = @OldOwner + '.' + rtrim(@Name) c1r+?q$f  
  exec sp_changeobjectowner @OwnerName, @NewOwner m)LI| v  
end jO/cdLKX(  
-- select @name,@NewOwner,@OldOwner Faa>bc~E  
FETCH NEXT FROM curObject INTO @Name, @Owner {6WG  
END q 7 <d|s  
close curObject OR*JWW[]  
deallocate curObject 3HBh 3p5  
GO +q;{ %3C  
10、SQL SERVER中直接循环写入数据 hv?T}E  
declare @i int "M@&*<S  
set @i=1 }*U|^$FEU  
while @i<30 YU"/p|!1  
begin I 44]W&  
  insert into test (userid) values(@i) i]N<xcF9N*  
  set @i=@i+1 w@&z0ODJ  
end I`*5z;Q!%@  
小记存储过程中经常用到的本周,本月,本年函数 S0Io$\ha  
Dateadd(wk,datediff(wk,0,getdate()),-1) kz1#"8Zd!  
Dateadd(wk,datediff(wk,0,getdate()),6) /a<UKh:A[  
Dateadd(mm,datediff(mm,0,getdate()),0) U<Tv<7`  
Dateadd(ms,-3,dateadd(mm,datediff(m,0,getdate())+1,0)) [*Ai@:F  
Dateadd(yy,datediff(yy,0,getdate()),0) $8i`h}AM  
Dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0)) 934j5D  
上面的SQL代码只是一个时间段 %8 D>aS U  
Dateadd(wk,datediff(wk,0,getdate()),-1) g1|Py t{  
Dateadd(wk,datediff(wk,0,getdate()),6) oH+PlL  
就是表示本周时间段. XI ;] c5  
下面的SQL的条件部分,就是查询时间段在本周范围内的: t$%<eF@w  
Where Time BETWEEN Dateadd(wk,datediff(wk,0,getdate()),-1) AND Dateadd(wk,datediff(wk,0,getdate()),6) Pc=ei  
而在存储过程中 FwlD P  
select @begintime = Dateadd(wk,datediff(wk,0,getdate()),-1) 8'L:D  
select @endtime = Dateadd(wk,datediff(wk,0,getdate()),6) vBOY[>=  
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

描述
快速回复

您目前还是游客,请 登录注册
温馨提示:欢迎交流讨论,请勿纯表情、纯引用!
认证码:
验证问题:
3+5=?,请输入中文答案:八 正确答案:八