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

[转贴]精妙SQL语句收集

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

SQL语句先前写的时候,很容易把一些特殊的用法忘记,我特此整理了一下SQL语句操作。 \'n$&PFe  
+ $>N]1  
IE&_!ce  
一、基础 x!'7yx  
1、说明:创建数据库 f?,-j>[.=f  
CREATE DATABASE database-name Q]< (bD.7  
2、说明:删除数据库 f#@S*^%V$  
drop database dbname tf4*R_6;1$  
3、说明:备份sql server Y4QLs^IdB  
--- 创建 备份数据的 device 2 9q?$V(  
USE master hlX>K  
EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' $bk>kbl P  
--- 开始 备份 r=h8oUNEJ*  
BACKUP DATABASE pubs TO testBack KwS`3 6:  
4、说明:创建新表 JW=uK$sO  
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..) Z.!g9fi8>  
根据已有的表创建新表: @gNpJB]V  
A:create table tab_new like tab_old (使用旧表创建新表) E]NY (1  
B:create table tab_new as select col1,col2... from tab_old definition only x_yF|]aI!  
5、说明:删除新表 BsKbn@'uC  
drop table tabname o6*/o ]]  
6、说明:增加一个列 ] bIt@GB  
Alter table tabname add column col type IWQ&6SDW$z  
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。 : (cb2j(C  
7、说明:添加主键: Alter table tabname add primary key(col) .N5'.3  
说明:删除主键: Alter table tabname drop primary key(col) DB#$~(o  
8、说明:创建索引:create [unique] index idxname on tabname(col....) +4Q[N;[+*  
删除索引:drop index idxname lqF>=15  
注:索引是不可更改的,想更改必须删除重新建。 8$ic~eJ  
9、说明:创建视图:create view viewname as select statement sH%&+4!3  
删除视图:drop view viewname D-6  
10、说明:几个简单的基本的sql语句 oew|23Ytb  
选择:select * from table1 where 范围 7R: WX:  
插入:insert into table1(field1,field2) values(value1,value2) B22b&0  
删除:delete from table1 where 范围 m=H_?W;  
更新:update table1 set field1=value1 where 范围 P@C c]Z  
查找:select * from table1 where field1 like '%value1%' ---like的语法很精妙,查资料! Jz0K}^Dj[  
排序:select * from table1 order by field1,field2 [desc] o5P&JBX<  
总数:select count as totalcount from table1 `|Ey)@w  
求和:select sum(field1) as sumvalue from table1 QP:9%f>=  
平均:select avg(field1) as avgvalue from table1 HcA[QBh  
最大:select max(field1) as maxvalue from table1 okz]Qc>G  
最小:select min(field1) as minvalue from table1 pajy#0 U  
AuAT]`  
gwiR/(1  
PcB{ = L  
11、说明:几个高级查询运算词 iX{H,- C  
BhLZ7*  
I0iY+@^5  
A: UNION 运算符 4`s)ue  
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。 .U 39nd  
B: EXCEPT 运算符 gKWzFnW  
EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。 >b>gr OX  
C: INTERSECT 运算符 +#~O'r]%GG  
INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。 .Vmtx  
注:使用运算词的几个查询结果行必须是一致的。 .a:Z!KF  
12、说明:使用外连接 +`| mJa  
A、left outer join: Zi/-~')E  
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。 )pS8{c)E  
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 <1 S+ '  
B:right outer join: KaW~ERx5  
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。 zw]3Vg{T  
C:full outer join: 0~]QIdu{AR  
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。 b/nOdFO@  
K_>/lirE?  
#/ +I*B*y  
二、提升 B'p5M.6d#:  
1、说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用) A#35]V06  
法一:select * into b from a where 1<>1 xl8#=qmCD  
法二:select top 0 * into b from a vU}: U)S  
2、说明:拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用) ?L\z}0#  
insert into b(a, b, c) select d,e,f from b; C`0%C7  
3、说明:跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用) @8zT'/$  
insert into b(a, b, c) select d,e,f from b in '具体数据库' where 条件 o8{<qn|  
例子:..from b in '"&Server.MapPath(".")&"\data.mdb" &"' where.. >S'>!w  
4、说明:子查询(表名1:a 表名2:b) 2ce'fMV  
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) O&V[g>x"U  
5、说明:显示文章、提交人和最后回复时间 &Mj1CvCv  
select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b ;& ~929  
6、说明:外连接查询(表名1:a 表名2:b) !BUi)mo  
select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c Q>=-ext}q  
7、说明:在线视图查询(表名1:a ) gI{ =0  
select * from (SELECT a,b,c FROM a) T where t.a > 1; SA+d&H}Fc  
8、说明:between的用法,between限制查询数据范围时包括了边界值,not between不包括 &SmXI5>Bo0  
select * from table1 where time between time1 and time2 t77'fm  
select a,b,c, from table1 where a not between 数值1 and 数值2 ,QvYTJ{  
9、说明:in 的使用方法 @.ZL7$|d  
select * from table1 where a [not] in ('值1','值2','值4','值6') x: ~d@  
10、说明:两张关联表,删除主表中已经在副表中没有的信息 a5?A!k\2  
delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 ) B {aU;{1  
11、说明:四表联查问题: W-XpJ\_  
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 ..... ffk4mhH  
12、说明:日程安排提前五分钟提醒 wyw<jH  
SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5 tS<h8g_  
13、说明:一条sql 语句搞定数据库分页 XWtiwf'K  
select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段 nU17L6'$  
14、说明:前10条记录 PN &|8_  
select top 10 * form table1 where 范围 azX`oU,l  
15、说明:选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.) )%VCzye*{  
select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b) %[ Zz0|A  
16、说明:包括所有在 TableA 中但不在 TableB和TableC 中的行并消除所有重复行而派生出一个结果表 )GJP_*Ab  
(select a from tableA ) except (select a from tableB) except (select a from tableC) fHfY}BQS  
17、说明:随机取出10条数据 )gXTRkmw  
select top 10 * from tablename order by newid() eYEc^nC,c)  
18、说明:随机选择记录 ZEGd4_ux  
select newid() Pp*}R2  
19、说明:删除重复记录 ~@P)tl>  
Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...) wmYvD<  
20、说明:列出数据库里所有的表名 31}W6l88c  
select name from sysobjects where type='U' 9j#@p   
21、说明:列出表里的所有的 A[H;WKn0  
select name from syscolumns where id=object_id('TableName') C9jbv/c  
22、说明:列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。 0H[LS  
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 U$'y_}V  
显示结果: >nry0 ;z0,  
type vender pcs "EH,J  
电脑 A 1 FkB{ SC J  
电脑 A 1 Mr* |9h  
光盘 B 2 S$O,] @)  
光盘 A 2 +(mL~td01  
手机 B 3 dJl^ADX[@  
手机 C 3 ({M?Q>s  
23、说明:初始化表table1 [ H,u)8)  
TRUNCATE TABLE table1 !8$RBD %  
24、说明:选择从10到15的记录  YqU/\f+  
select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc JJ5C}`(  
=M<z8R  
;'3]{BGcU  
$Ha%Gr  
三、技巧 |Q!4GeQL[  
1、1=1,1=2的使用,在SQL语句组合时用的较多 p)/ p!d[T/  
"where 1=1" 是表示选择全部  "where 1=2"全部不选, 'qy#)F  
如: 7lU.Ni t  
if @strWhere !='' o.^y1mH'  
begin 2U9&l1P=  
set @strSQL = 'select count(*) as Total from [' + @tblName + '] where ' + @strWhere ` X}85  
end / Z!i;@Wf  
else D$nK`r  
begin p5<2N  
set @strSQL = 'select count(*) as Total from [' + @tblName + ']' /2@["*^$  
end 4;*f1_;f~  
我们可以直接写成 X/+OF'po  
set @strSQL = 'select count(*) as Total from [' + @tblName + '] where 1=1 安定 '+ @strWhere 0{R/<N  
2、收缩数据库 I/B1qw;MN  
--重建索引 xK;e\^v  
DBCC REINDEX "^%Z'ou  
DBCC INDEXDEFRAG (p |DcA]BX  
--收缩数据和日志 h\y-L~2E  
DBCC SHRINKDB ut5yf$%  
DBCC SHRINKFILE BXhWTGiG  
3、压缩数据库 s;{K!L@  
dbcc shrinkdatabase(dbname) ez*jjm  
4、转移数据库给新用户以已存在用户权限 iP "EA8  
exec sp_change_users_login 'update_one','newname','oldname' =nVmthGw  
go 6vp0*ww  
5、检查备份集 HFS+QwHW  
RESTORE VERIFYONLY from disk='E:\dvbbs.bak' m mw-a0  
6、修复数据库 6c<ezEJ  
ALTER DATABASE [dvbbs] SET SINGLE_USER Q6^x8  
GO 6fwY$K\X  
DBCC CHECKDB('dvbbs',repair_allow_data_loss) WITH TABLOCK T=\!2gt  
GO )^ <3\e  
ALTER DATABASE [dvbbs] SET MULTI_USER ?63&g{vA  
GO \##`pa(8  
7、日志清除 +v15[^F  
SET NOCOUNT ON  Q2\  
DECLARE @LogicalFileName sysname, $(q8y/,R*-  
        @MaxMinutes INT, G;]:$J  
        @NewSize INT _N'75  
USE    tablename            -- 要操作的数据库名 )|]Z>>%t  
SELECT  @LogicalFileName = 'tablename_log',  -- 日志文件名 )+Y&4Qu  
@MaxMinutes = 10,              -- Limit on time allowed to wrap log. hI~SAd ,#A  
        @NewSize = 1                  -- 你想设定的日志文件的大小(M) !k<:k "7  
-- Setup / initialize ]rW8y%yD  
DECLARE @OriginalSize int AS;.sjgk  
SELECT @OriginalSize = size G|9B )`S  
  FROM sysfiles z{?4*Bq  
  WHERE name = @LogicalFileName yP\Up  
SELECT 'Original Size of ' + db_name() + ' LOG is ' + ("Dv>&w9  
        CONVERT(VARCHAR(30),@OriginalSize) + ' 8K pages or ' + 5 09Q0 [k  
        CONVERT(VARCHAR(30),(@OriginalSize*8/1024)) + 'MB' z[&s5"  
  FROM sysfiles ]k+m=OR{/  
  WHERE name = @LogicalFileName -<W2PY<  
CREATE TABLE DummyTrans ?_ RYqolz  
  (DummyColumn char (8000) not null) rsF:4G"%  
DECLARE @Counter  INT, JSW&rn  
        @StartTime DATETIME, e.;M.8N#SQ  
        @TruncLog  VARCHAR(255) )U(u>SV(\  
SELECT  @StartTime = GETDATE(), ^7u#30,}3~  
        @TruncLog = 'BACKUP LOG ' + db_name() + ' WITH TRUNCATE_ONLY' (5`T+pAsV  
DBCC SHRINKFILE (@LogicalFileName, @NewSize) 'sU)|W(3U  
EXEC (@TruncLog) O&$0&dhc  
-- Wrap the log if necessary. G) 7)]yBL  
WHILE    @MaxMinutes > DATEDIFF (mi, @StartTime, GETDATE()) -- time has not expired 9 5 H?{  
      AND @OriginalSize = (SELECT size FROM sysfiles WHERE name = @LogicalFileName)  ,Y!zORv<7  
      AND (@OriginalSize * 8 /1024) > @NewSize  @ajM^L!O  
  BEGIN -- Outer loop. 9]$`)wZ  
    SELECT @Counter = 0 Y}.Ystem  
    WHILE  ((@Counter < @OriginalSize / 16) AND (@Counter < 50000)) /iC_!nu  
      BEGIN -- update WE.Tuo5L  
        INSERT DummyTrans VALUES ('Fill Log')  [7\>"v6  
        DELETE DummyTrans w O!u!I  
        SELECT @Counter = @Counter + 1 JTUNb'#RZ  
      END  |:2c$zq  
    EXEC (@TruncLog)  h>3H7n.  
  END  OM!=ViN(=  
SELECT 'Final Size of ' + db_name() + ' LOG is ' + s4t0f_vj`  
        CONVERT(VARCHAR(30),size) + ' 8K pages or ' + xzk}[3P{  
        CONVERT(VARCHAR(30),(size*8/1024)) + 'MB' v0 ];W|  
  FROM sysfiles !N~*EI$  
  WHERE name = @LogicalFileName )H+kB<n  
DROP TABLE DummyTrans hC>wFC  
SET NOCOUNT OFF (cs~@  
8、说明:更改某个表 B8~= RmWLl  
exec sp_changeobjectowner 'tablename','dbo' 4/MNqit+  
9、存储更改全部表 8:{ q8xZ=k  
CREATE PROCEDURE dbo.User_ChangeObjectOwnerBatch #x~_`>mDN  
@OldOwner as NVARCHAR(128), -e*BqH2t  
@NewOwner as NVARCHAR(128) +X^4; &  
AS ~`Sle xK|}  
DECLARE @Name  as NVARCHAR(128) zilaP)5x6  
DECLARE @Owner  as NVARCHAR(128) Kbas-</Si  
DECLARE @OwnerName  as NVARCHAR(128) sv=H~wce  
DECLARE curObject CURSOR FOR 8p =>?wG  
select 'Name'  = name, ct0v$ct>f  
  'Owner'  = user_name(uid) -,GEv%6c  
from sysobjects K0<yvew  
where user_name(uid)=@OldOwner &=zU611,  
order by name hTw}X.<4  
OPEN  curObject ;r!\-]5$  
FETCH NEXT FROM curObject INTO @Name, @Owner @HEPc95  
WHILE(@@FETCH_STATUS=0) 263*: Y  
BEGIN    }W}G X(?P  
if @Owner=@OldOwner fn1pa@P  
begin oT->^4WY  
  set @OwnerName = @OldOwner + '.' + rtrim(@Name) F= i!d,S  
  exec sp_changeobjectowner @OwnerName, @NewOwner EcW1;wH  
end A&l7d0Z^j5  
-- select @name,@NewOwner,@OldOwner !$r9C/k  
FETCH NEXT FROM curObject INTO @Name, @Owner H[BYE  
END }17bV, t  
close curObject Nza; O[  
deallocate curObject .)`-Hkxa  
GO Gl>E[iO  
10、SQL SERVER中直接循环写入数据 vYzVY\   
declare @i int rfTe  
set @i=1 IJIQ" s  
while @i<30 ][t 6VA  
begin [ &daG:  
  insert into test (userid) values(@i) 'w6hW7"L  
  set @i=@i+1 $e1:Q#den2  
end ;eh/_hPM  
小记存储过程中经常用到的本周,本月,本年函数 Omb.53+  
Dateadd(wk,datediff(wk,0,getdate()),-1) ohplj`X[21  
Dateadd(wk,datediff(wk,0,getdate()),6) 8uA<G/Q;  
Dateadd(mm,datediff(mm,0,getdate()),0) d h?dO`  
Dateadd(ms,-3,dateadd(mm,datediff(m,0,getdate())+1,0)) k<O y%+C  
Dateadd(yy,datediff(yy,0,getdate()),0) lh$CWsx  
Dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0)) o=mo/N4  
上面的SQL代码只是一个时间段 -yA3 RP  
Dateadd(wk,datediff(wk,0,getdate()),-1) LP?P=c  
Dateadd(wk,datediff(wk,0,getdate()),6) GLcd9|H  
就是表示本周时间段. GBr,LN  
下面的SQL的条件部分,就是查询时间段在本周范围内的: `EVg'?pl  
Where Time BETWEEN Dateadd(wk,datediff(wk,0,getdate()),-1) AND Dateadd(wk,datediff(wk,0,getdate()),6) yM|g|;U  
而在存储过程中 s7M}NA 0  
select @begintime = Dateadd(wk,datediff(wk,0,getdate()),-1) - 3]|[  
select @endtime = Dateadd(wk,datediff(wk,0,getdate()),6) en%B>]QI  
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水

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

描述
快速回复

您目前还是游客,请 登录注册
欢迎提供真实交流,考虑发帖者的感受
认证码:
验证问题:
10+5=?,请输入中文答案:十五