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

[转贴]精妙SQL语句收集

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

SQL语句先前写的时候,很容易把一些特殊的用法忘记,我特此整理了一下SQL语句操作。 (H$eXW7  
f: R h9  
*M{1RMc  
一、基础 hRP0Djc  
1、说明:创建数据库 ,#crtX  
CREATE DATABASE database-name A)xI. Q6  
2、说明:删除数据库 .+y#7-#6  
drop database dbname *)`:Nm~y  
3、说明:备份sql server qcK)J/K"  
--- 创建 备份数据的 device }V 1sY^C  
USE master 0t) IW D  
EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' z# y<QH  
--- 开始 备份 -I -wdyDr  
BACKUP DATABASE pubs TO testBack -$7Jc=:>  
4、说明:创建新表 /<mc~S7  
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..) \sk,3b-&'  
根据已有的表创建新表: "-a>Uj")%  
A:create table tab_new like tab_old (使用旧表创建新表) yH Cc@`1.  
B:create table tab_new as select col1,col2... from tab_old definition only e"v Eh  
5、说明:删除新表 m>iuy:ti  
drop table tabname ~Sh}\&3p  
6、说明:增加一个列 @t_<oOI2  
Alter table tabname add column col type * 08LW|:,  
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。 /F\7_  
7、说明:添加主键: Alter table tabname add primary key(col) p'H5yg3h  
说明:删除主键: Alter table tabname drop primary key(col) 8w{V[@QLn  
8、说明:创建索引:create [unique] index idxname on tabname(col....) xe5>)\18-  
删除索引:drop index idxname rJAY7/u  
注:索引是不可更改的,想更改必须删除重新建。 "PX~Yc  
9、说明:创建视图:create view viewname as select statement 9`xq3EL2T  
删除视图:drop view viewname Qwb@3{  
10、说明:几个简单的基本的sql语句 <Sz9: hg-  
选择:select * from table1 where 范围 U9JqZ!  
插入:insert into table1(field1,field2) values(value1,value2) m_pK'jc  
删除:delete from table1 where 范围 @FQ@* XD  
更新:update table1 set field1=value1 where 范围 &?~> I[^~  
查找:select * from table1 where field1 like '%value1%' ---like的语法很精妙,查资料! -/h$Yb  
排序:select * from table1 order by field1,field2 [desc] , 7}Ri  
总数:select count as totalcount from table1 4F'@yi^Gt  
求和:select sum(field1) as sumvalue from table1 >6@UjGj54  
平均:select avg(field1) as avgvalue from table1 b&LhydaJ  
最大:select max(field1) as maxvalue from table1 =/zQJzN  
最小:select min(field1) as minvalue from table1 R)#"Ab Z'  
_8bqk\m+  
P?bdjU#_n`  
5f1yszd  
11、说明:几个高级查询运算词 zP5HTEz  
rIu>JyC"p  
\\[P^ tsF  
A: UNION 运算符 Ar|_UV>Zf  
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。 Wjj'yqBO^  
B: EXCEPT 运算符 }b1P!xb!A  
EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。 $Q?UyEi  
C: INTERSECT 运算符 Ngg (<ZN  
INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。 Cu0/TeEM  
注:使用运算词的几个查询结果行必须是一致的。 W] RxRdY6[  
12、说明:使用外连接 +jHL==W&  
A、left outer join: U7{, *  
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。 9;:Lf  
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 xEbcF+@  
B:right outer join: wt-)5f'{  
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。 0n5N-b?G-@  
C:full outer join: `AYHCn  
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。 HIF.;ImG^  
oqG 0 @@  
<}|+2f233+  
二、提升 u\6:Txqq  
1、说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用) v=|ahsYC  
法一:select * into b from a where 1<>1 >ztv3^w  
法二:select top 0 * into b from a W4Zi?@L>'  
2、说明:拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用) dD#A.C,Rz  
insert into b(a, b, c) select d,e,f from b; S]k<Ixvf  
3、说明:跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用) ETYw  
insert into b(a, b, c) select d,e,f from b in '具体数据库' where 条件 d kPfdK}G  
例子:..from b in '"&Server.MapPath(".")&"\data.mdb" &"' where.. *`|F?wF  
4、说明:子查询(表名1:a 表名2:b) Cfa?LgSz  
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) KpSHf9!&[  
5、说明:显示文章、提交人和最后回复时间 Y@Ty_j~  
select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b U*)pUJ{&t  
6、说明:外连接查询(表名1:a 表名2:b) N'TL &]  
select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c 2LXy$[)7  
7、说明:在线视图查询(表名1:a ) Zsaz#z|xW  
select * from (SELECT a,b,c FROM a) T where t.a > 1; VNF@)!l  
8、说明:between的用法,between限制查询数据范围时包括了边界值,not between不包括 Zpg$:Rr  
select * from table1 where time between time1 and time2 75gE>:f  
select a,b,c, from table1 where a not between 数值1 and 数值2 Dk/;`sXV  
9、说明:in 的使用方法 9^ )=N=wV  
select * from table1 where a [not] in ('值1','值2','值4','值6') #p0vrQ;5f  
10、说明:两张关联表,删除主表中已经在副表中没有的信息 I:[3x2H  
delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 ) {G_ZEo#x8,  
11、说明:四表联查问题: eqYa`h@g^  
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 ..... fAYm3+.l3  
12、说明:日程安排提前五分钟提醒 IEHAPt'  
SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5 u PjJ>v  
13、说明:一条sql 语句搞定数据库分页 l\a 0 k4  
select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段 2}t2k>  
14、说明:前10条记录 TN(1oJ:  
select top 10 * form table1 where 范围 W,}C*8{+  
15、说明:选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.) m\[r6t]V  
select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b) |6$6Za]:  
16、说明:包括所有在 TableA 中但不在 TableB和TableC 中的行并消除所有重复行而派生出一个结果表 Hj LY\.S  
(select a from tableA ) except (select a from tableB) except (select a from tableC) L= hPu#&/  
17、说明:随机取出10条数据 @MTm8E6au  
select top 10 * from tablename order by newid() ShFSBD\M#  
18、说明:随机选择记录 GJU84Xn7  
select newid() , LX]  
19、说明:删除重复记录 =fEn h'KE  
Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...) :4/RB%)"  
20、说明:列出数据库里所有的表名 Yaht<Hy  
select name from sysobjects where type='U' B xq(+^T  
21、说明:列出表里的所有的 ^lf{IM-Y  
select name from syscolumns where id=object_id('TableName') Wfz&:J#  
22、说明:列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。 e%SQ~n=H 9  
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 p Gzzv{H  
显示结果: ,{=#  
type vender pcs < OCy  
电脑 A 1 3 rV)JA  
电脑 A 1 #D&eov?  
光盘 B 2 =rGjOb3+  
光盘 A 2 Az{Z=:(0  
手机 B 3 l>Z"y\l =  
手机 C 3 *?+E?AGe  
23、说明:初始化表table1 UOi8>;k`  
TRUNCATE TABLE table1 "}Vow^vb  
24、说明:选择从10到15的记录 +.:- :  
select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc &V:iy  
#zyEN+  
)u`q41!  
L slI!.(  
三、技巧 :[?hU}9  
1、1=1,1=2的使用,在SQL语句组合时用的较多 ?V3e;n  
"where 1=1" 是表示选择全部  "where 1=2"全部不选, QJjqtOf>  
如: 3a_~18W  
if @strWhere !='' ZG"_M@S.  
begin Z~CL|=  
set @strSQL = 'select count(*) as Total from [' + @tblName + '] where ' + @strWhere s,)Z8H  
end = a$7OV.  
else *shE-w ;C  
begin Gk g)\ 3  
set @strSQL = 'select count(*) as Total from [' + @tblName + ']' N*gnwrP{  
end sFuB[ JJ}  
我们可以直接写成 V'K1kYb  
set @strSQL = 'select count(*) as Total from [' + @tblName + '] where 1=1 安定 '+ @strWhere := C-P7  
2、收缩数据库 <!Ed ND=  
--重建索引 q ^Un,h64t  
DBCC REINDEX S=@.<gS  
DBCC INDEXDEFRAG gi#bU  
--收缩数据和日志 UOC>H%r~M?  
DBCC SHRINKDB [W;iR_7T5  
DBCC SHRINKFILE tN&4t xB  
3、压缩数据库 pX `BDYg.  
dbcc shrinkdatabase(dbname) w3WBgH  
4、转移数据库给新用户以已存在用户权限 slaYr`u  
exec sp_change_users_login 'update_one','newname','oldname' #?DwOUw  
go bz<f u  
5、检查备份集 t2uX+1F  
RESTORE VERIFYONLY from disk='E:\dvbbs.bak' ).0klwfV  
6、修复数据库 B+:/!_  
ALTER DATABASE [dvbbs] SET SINGLE_USER i=jwk_y  
GO | vL0}e  
DBCC CHECKDB('dvbbs',repair_allow_data_loss) WITH TABLOCK pyJY]"UHVE  
GO E<]O,z;F  
ALTER DATABASE [dvbbs] SET MULTI_USER  Wa7-N4  
GO DybuLB$f  
7、日志清除 )7jjfD\  
SET NOCOUNT ON #q#C_"  
DECLARE @LogicalFileName sysname, R OsR;C0!  
        @MaxMinutes INT, H]As2$[  
        @NewSize INT 8w /$!9[  
USE    tablename            -- 要操作的数据库名 3}~.#`QeY  
SELECT  @LogicalFileName = 'tablename_log',  -- 日志文件名 wr I66R}@  
@MaxMinutes = 10,              -- Limit on time allowed to wrap log. uj;tmK>;  
        @NewSize = 1                  -- 你想设定的日志文件的大小(M) cBZ$$$v\#  
-- Setup / initialize G'<:O(Imu  
DECLARE @OriginalSize int Mtq\xF,/+  
SELECT @OriginalSize = size /vO8s??  
  FROM sysfiles 8T-/G9u  
  WHERE name = @LogicalFileName i[_B~/_  
SELECT 'Original Size of ' + db_name() + ' LOG is ' + '-c *S]:r  
        CONVERT(VARCHAR(30),@OriginalSize) + ' 8K pages or ' + /6",#B}%b  
        CONVERT(VARCHAR(30),(@OriginalSize*8/1024)) + 'MB' -|V1A[  
  FROM sysfiles imw,Nb  
  WHERE name = @LogicalFileName @ >_v/U'  
CREATE TABLE DummyTrans p?rh+0wgX  
  (DummyColumn char (8000) not null) |iSd<  
DECLARE @Counter  INT, Wg{ 9X#|  
        @StartTime DATETIME, ]t0]fb[J  
        @TruncLog  VARCHAR(255) o?5m^S14[1  
SELECT  @StartTime = GETDATE(), *Cf5D6=Q  
        @TruncLog = 'BACKUP LOG ' + db_name() + ' WITH TRUNCATE_ONLY' {02$pO  
DBCC SHRINKFILE (@LogicalFileName, @NewSize) +)$oy]  
EXEC (@TruncLog) rZ`+g7&^Fh  
-- Wrap the log if necessary. ,Y9bXC8+dU  
WHILE    @MaxMinutes > DATEDIFF (mi, @StartTime, GETDATE()) -- time has not expired !y_4.&C{  
      AND @OriginalSize = (SELECT size FROM sysfiles WHERE name = @LogicalFileName)  x9\z^GU%H  
      AND (@OriginalSize * 8 /1024) > @NewSize  Sq22]  
  BEGIN -- Outer loop. &`x1_*l  
    SELECT @Counter = 0 hvW FzT5  
    WHILE  ((@Counter < @OriginalSize / 16) AND (@Counter < 50000)) SzXR],dA  
      BEGIN -- update # `L?24%  
        INSERT DummyTrans VALUES ('Fill Log')  `st3iTLZY  
        DELETE DummyTrans %[S-"k  
        SELECT @Counter = @Counter + 1 t?1 b(oJ  
      END  [h&)h+xt  
    EXEC (@TruncLog)  ^cRAtoa  
  END  oD<aWZ"Z  
SELECT 'Final Size of ' + db_name() + ' LOG is ' + "qh~wKJ  
        CONVERT(VARCHAR(30),size) + ' 8K pages or ' + {0L.,T~g+[  
        CONVERT(VARCHAR(30),(size*8/1024)) + 'MB' =1#obB  
  FROM sysfiles m4\e `nl  
  WHERE name = @LogicalFileName R ?62g H  
DROP TABLE DummyTrans {:;6 *W  
SET NOCOUNT OFF OTe h8h  
8、说明:更改某个表 (fNG51h!  
exec sp_changeobjectowner 'tablename','dbo' At<D36,^"  
9、存储更改全部表 ~dXiyU,y2  
CREATE PROCEDURE dbo.User_ChangeObjectOwnerBatch ;*(i}'  
@OldOwner as NVARCHAR(128), (>49SOu;$\  
@NewOwner as NVARCHAR(128) ~}"5KX\=#  
AS g79zzi-  
DECLARE @Name  as NVARCHAR(128) ibP IT!5c  
DECLARE @Owner  as NVARCHAR(128) 3ch<a0  
DECLARE @OwnerName  as NVARCHAR(128) +-X 6 8`  
DECLARE curObject CURSOR FOR ,{6 Vf|?  
select 'Name'  = name, )x5t']w`K  
  'Owner'  = user_name(uid) c,j[ix  
from sysobjects '8w}m8{y  
where user_name(uid)=@OldOwner CKE):kHu  
order by name MD98N{+[|  
OPEN  curObject :MaP58dhh  
FETCH NEXT FROM curObject INTO @Name, @Owner y:',)f }  
WHILE(@@FETCH_STATUS=0) Efp[K}Z^$  
BEGIN    q!;u4J  
if @Owner=@OldOwner )&6ZgRq  
begin o' EJ,8  
  set @OwnerName = @OldOwner + '.' + rtrim(@Name) *q&^tn b  
  exec sp_changeobjectowner @OwnerName, @NewOwner TI/5'Oke$  
end @ / .w%  
-- select @name,@NewOwner,@OldOwner Y;)l  
FETCH NEXT FROM curObject INTO @Name, @Owner P+L#p(K  
END :X*$U ~aQ  
close curObject S:lie*Aux*  
deallocate curObject eC{St0  
GO gWD46+A){  
10、SQL SERVER中直接循环写入数据 A Xpg_JC  
declare @i int .QU]  
set @i=1 x?7z15\  
while @i<30 4^Ke? ;v  
begin C;3  
  insert into test (userid) values(@i) Y 'y yrn}  
  set @i=@i+1 8|L;y[v  
end &>f]  
小记存储过程中经常用到的本周,本月,本年函数 %63s(ekU  
Dateadd(wk,datediff(wk,0,getdate()),-1) 0^3n#7m;K  
Dateadd(wk,datediff(wk,0,getdate()),6) RNo~}#  
Dateadd(mm,datediff(mm,0,getdate()),0) QQ,V35Vp[  
Dateadd(ms,-3,dateadd(mm,datediff(m,0,getdate())+1,0)) + mPVI  
Dateadd(yy,datediff(yy,0,getdate()),0) &#zx/$  
Dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0)) 6$)FQ U  
上面的SQL代码只是一个时间段 8'PK}heBU  
Dateadd(wk,datediff(wk,0,getdate()),-1) M3G ecjR  
Dateadd(wk,datediff(wk,0,getdate()),6) m Ce"=[  
就是表示本周时间段. h_HPmh5  
下面的SQL的条件部分,就是查询时间段在本周范围内的: mY[*(a  
Where Time BETWEEN Dateadd(wk,datediff(wk,0,getdate()),-1) AND Dateadd(wk,datediff(wk,0,getdate()),6) B3 |G&Kg  
而在存储过程中 (u4'*[o\t  
select @begintime = Dateadd(wk,datediff(wk,0,getdate()),-1) -}1TT@  
select @endtime = Dateadd(wk,datediff(wk,0,getdate()),6) MWv(/_b  
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水

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

描述
快速回复

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