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

[转贴]精妙SQL语句收集

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

SQL语句先前写的时候,很容易把一些特殊的用法忘记,我特此整理了一下SQL语句操作。 4a "Fu<q  
:#pdyJQ_  
m^G(qoZ]  
一、基础 P0jr>j@^-  
1、说明:创建数据库 yB2h/~+  
CREATE DATABASE database-name {VE h@yn  
2、说明:删除数据库 z.!N|"4yr  
drop database dbname L_NiU;cr%  
3、说明:备份sql server e[fOm0^.c  
--- 创建 备份数据的 device *B"Y]6$  
USE master ylKK!vRHT  
EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' v$W[(  
--- 开始 备份 J6AHc"k.  
BACKUP DATABASE pubs TO testBack `(sb  
4、说明:创建新表 sfj+-se(K.  
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..) DzQBWY] )  
根据已有的表创建新表: 12KC4,C&1i  
A:create table tab_new like tab_old (使用旧表创建新表) =d<RgwscJ  
B:create table tab_new as select col1,col2... from tab_old definition only 0(D^NtB7  
5、说明:删除新表 /v8Q17O?e  
drop table tabname 4 "HX1qP  
6、说明:增加一个列 1!~cPD'F  
Alter table tabname add column col type 2t-w0~O  
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。 n%s%i-[5B  
7、说明:添加主键: Alter table tabname add primary key(col) \A"o[A2v  
说明:删除主键: Alter table tabname drop primary key(col) /.Ak'Vmi  
8、说明:创建索引:create [unique] index idxname on tabname(col....) ]:59c{O  
删除索引:drop index idxname ^ RA'E@ "  
注:索引是不可更改的,想更改必须删除重新建。 Aw |;C  
9、说明:创建视图:create view viewname as select statement 6 :] N%  
删除视图:drop view viewname l9Ir@.m  
10、说明:几个简单的基本的sql语句 kg[%Q]]  
选择:select * from table1 where 范围 g[3LPKQ  
插入:insert into table1(field1,field2) values(value1,value2) /i'078F  
删除:delete from table1 where 范围 _U<fS  
更新:update table1 set field1=value1 where 范围 \ ;npdFy  
查找:select * from table1 where field1 like '%value1%' ---like的语法很精妙,查资料! fkBL`[v)4  
排序:select * from table1 order by field1,field2 [desc] K^shTh8k  
总数:select count as totalcount from table1 QO/0VB42  
求和:select sum(field1) as sumvalue from table1 50W+!'  
平均:select avg(field1) as avgvalue from table1 ["Ltqgx  
最大:select max(field1) as maxvalue from table1 5^u$zfR  
最小:select min(field1) as minvalue from table1 `hi=y BO  
<+i(CGw  
vxOqo)yO  
&12K pEyf  
11、说明:几个高级查询运算词 _\ToA9m  
b-&iJ &>'  
;u UFgDi  
A: UNION 运算符 [1VA`:?W  
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。 QPJ \Iu@D$  
B: EXCEPT 运算符 d(T4Kd$r  
EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。 CubQ6@,  
C: INTERSECT 运算符 {AL EK   
INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。 c=oDzAzuV\  
注:使用运算词的几个查询结果行必须是一致的。 Y%s:oHt  
12、说明:使用外连接 Ke\\B o,  
A、left outer join: HTJ2D@h  
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。 6pt_cpbR  
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 fu/8r%:h  
B:right outer join: hmO2s/~  
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。 lLx!_h  
C:full outer join: m+kP"]v  
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。 {^VtD  
}TmOoi(X@  
~~tTr $  
二、提升 U(#<D7}  
1、说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用) {ez $kz  
法一:select * into b from a where 1<>1 t4WB^dHYp  
法二:select top 0 * into b from a ~s!Q0G^G  
2、说明:拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用) a1U|eLmUb  
insert into b(a, b, c) select d,e,f from b; b(H{i}{]  
3、说明:跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用) zX>W 8P  
insert into b(a, b, c) select d,e,f from b in '具体数据库' where 条件 Dqx#i-L23  
例子:..from b in '"&Server.MapPath(".")&"\data.mdb" &"' where.. x sryXex;  
4、说明:子查询(表名1:a 表名2:b) Zv u6/#  
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) Z/#_Swv  
5、说明:显示文章、提交人和最后回复时间 Z*%;;&?  
select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b m1"m KM  
6、说明:外连接查询(表名1:a 表名2:b) yB b%#GW  
select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c /`*{57/3  
7、说明:在线视图查询(表名1:a ) =}^NyLE?  
select * from (SELECT a,b,c FROM a) T where t.a > 1; eU yF<j  
8、说明:between的用法,between限制查询数据范围时包括了边界值,not between不包括 Jl Do_}  
select * from table1 where time between time1 and time2 Kc MzY  
select a,b,c, from table1 where a not between 数值1 and 数值2 9u B?-.  
9、说明:in 的使用方法 (#Y~z',I  
select * from table1 where a [not] in ('值1','值2','值4','值6') Xn6#q3;^|  
10、说明:两张关联表,删除主表中已经在副表中没有的信息 A6N6e\*  
delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 ) xY^sC56Z  
11、说明:四表联查问题: )g0lI  
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 ..... h0GoF A<  
12、说明:日程安排提前五分钟提醒 @I _cwUO  
SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5 I{Zb/}k-  
13、说明:一条sql 语句搞定数据库分页 ) r2Y@+.FN  
select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段 _bFUr  
14、说明:前10条记录 M";qo6  
select top 10 * form table1 where 范围 3nq?Y8yac  
15、说明:选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.) q2qi~}l  
select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b) 6j<9Y  
16、说明:包括所有在 TableA 中但不在 TableB和TableC 中的行并消除所有重复行而派生出一个结果表 P6:9o}K6  
(select a from tableA ) except (select a from tableB) except (select a from tableC) YG "Ta|@5  
17、说明:随机取出10条数据 L:R4&|E/t  
select top 10 * from tablename order by newid() TlqHj  
18、说明:随机选择记录 IGdiIhH~2  
select newid() "g{q=[U}  
19、说明:删除重复记录 m|a9T#B(  
Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...) :RaQ =C  
20、说明:列出数据库里所有的表名 >rSjP1-F  
select name from sysobjects where type='U' bjZJP\6  
21、说明:列出表里的所有的 067c/ c  
select name from syscolumns where id=object_id('TableName') z5+Pi:1w  
22、说明:列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。 *;7y5ZJ  
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 'solCAy  
显示结果: :cT)M(o  
type vender pcs ~P4C`Q1PT#  
电脑 A 1 D -}>28  
电脑 A 1 Wh[QR-7Ew  
光盘 B 2 *$tXm4 O[  
光盘 A 2 *FS8]!Qg  
手机 B 3 `KJ( .m  
手机 C 3 a:kAo0@":j  
23、说明:初始化表table1 D31X {dJ  
TRUNCATE TABLE table1 VF%QM;I[Rc  
24、说明:选择从10到15的记录 %go2tv:|W  
select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc )H8_.]|  
;Rrh$Ag  
%pC<T*f  
,/;Ae w;  
三、技巧 1'kO{Ge*p:  
1、1=1,1=2的使用,在SQL语句组合时用的较多 X\}l" ]  
"where 1=1" 是表示选择全部  "where 1=2"全部不选, R+ * ; [  
如: pwFp<O"  
if @strWhere !='' =Tj{)=^/#  
begin &,X}M  
set @strSQL = 'select count(*) as Total from [' + @tblName + '] where ' + @strWhere mG~_*8}e<  
end ?w3RqF@}  
else =%Y1] F  
begin 6FUW^dt  
set @strSQL = 'select count(*) as Total from [' + @tblName + ']' YEL0h0gn  
end })g<I+]Hf9  
我们可以直接写成 /x VHd  
set @strSQL = 'select count(*) as Total from [' + @tblName + '] where 1=1 安定 '+ @strWhere @CprC]X  
2、收缩数据库 aukcO ;oG<  
--重建索引 tpfgUZ{  
DBCC REINDEX JGs: RD'  
DBCC INDEXDEFRAG --yF%tRMP  
--收缩数据和日志 h\s/rZg=r  
DBCC SHRINKDB CSM"Kz`  
DBCC SHRINKFILE PmR].Ohzi  
3、压缩数据库 "<,lqIqA;  
dbcc shrinkdatabase(dbname) ~Y 6'sM|  
4、转移数据库给新用户以已存在用户权限 O<u=Vz3c~0  
exec sp_change_users_login 'update_one','newname','oldname' S{c/3k~  
go *a9cBl'_  
5、检查备份集 *"%TAe7?~+  
RESTORE VERIFYONLY from disk='E:\dvbbs.bak' ]\, ?u /  
6、修复数据库 ["-rD y P  
ALTER DATABASE [dvbbs] SET SINGLE_USER z0"t]4s  
GO @rl5k(  
DBCC CHECKDB('dvbbs',repair_allow_data_loss) WITH TABLOCK r- 8Awa  
GO ^y+k6bE  
ALTER DATABASE [dvbbs] SET MULTI_USER mdi!Q1pS  
GO {u'szO}k  
7、日志清除 o`T.Zaik,  
SET NOCOUNT ON $)lkiA&;  
DECLARE @LogicalFileName sysname, KVi6vdgD  
        @MaxMinutes INT, ?N#I2jxaD  
        @NewSize INT !xs}CxEyA  
USE    tablename            -- 要操作的数据库名 /MZ<vnN7f  
SELECT  @LogicalFileName = 'tablename_log',  -- 日志文件名 2Q^ q$@L  
@MaxMinutes = 10,              -- Limit on time allowed to wrap log. i7x&[b  
        @NewSize = 1                  -- 你想设定的日志文件的大小(M) "LBMpgpU  
-- Setup / initialize 0~|0D#klB  
DECLARE @OriginalSize int aLk3Yg@X  
SELECT @OriginalSize = size fSo8O  
  FROM sysfiles 19 5_1?'<  
  WHERE name = @LogicalFileName 0'^M}&zCi  
SELECT 'Original Size of ' + db_name() + ' LOG is ' + Y}~sTuWU  
        CONVERT(VARCHAR(30),@OriginalSize) + ' 8K pages or ' + >xWS>  
        CONVERT(VARCHAR(30),(@OriginalSize*8/1024)) + 'MB' -@v^. @[Z&  
  FROM sysfiles iZGbNN  
  WHERE name = @LogicalFileName u 3WU0Z`  
CREATE TABLE DummyTrans {X!vb  
  (DummyColumn char (8000) not null) )CGQ}  
DECLARE @Counter  INT, P,v7twc0M  
        @StartTime DATETIME, r!r08y f  
        @TruncLog  VARCHAR(255) xfk -Ezv  
SELECT  @StartTime = GETDATE(), Yuv(4a<M%  
        @TruncLog = 'BACKUP LOG ' + db_name() + ' WITH TRUNCATE_ONLY' tXE/aY*I  
DBCC SHRINKFILE (@LogicalFileName, @NewSize) dOjly,!  
EXEC (@TruncLog) pF;.nt)  
-- Wrap the log if necessary. b 74 !Zw  
WHILE    @MaxMinutes > DATEDIFF (mi, @StartTime, GETDATE()) -- time has not expired ;-db/$O  
      AND @OriginalSize = (SELECT size FROM sysfiles WHERE name = @LogicalFileName)  d$ouH%^cGu  
      AND (@OriginalSize * 8 /1024) > @NewSize  x]^d'o:cDP  
  BEGIN -- Outer loop. D  T5d]MU  
    SELECT @Counter = 0 ; 476t  
    WHILE  ((@Counter < @OriginalSize / 16) AND (@Counter < 50000)) di\.*7l?  
      BEGIN -- update 5'!fi]Z  
        INSERT DummyTrans VALUES ('Fill Log')  &3vm @  
        DELETE DummyTrans >,6  
        SELECT @Counter = @Counter + 1 1[P}D~ nQ  
      END  pa-*&p  
    EXEC (@TruncLog)  D#GuF~-F!R  
  END  x{H+fq,M  
SELECT 'Final Size of ' + db_name() + ' LOG is ' + n:AZ(f   
        CONVERT(VARCHAR(30),size) + ' 8K pages or ' + Yy~x`P'g!  
        CONVERT(VARCHAR(30),(size*8/1024)) + 'MB' e$L C  
  FROM sysfiles ^ AZ#tp%)  
  WHERE name = @LogicalFileName b8!oZ~ K  
DROP TABLE DummyTrans 3.Fko<D4jD  
SET NOCOUNT OFF 2;)IBvK  
8、说明:更改某个表 /xn|d#4  
exec sp_changeobjectowner 'tablename','dbo' {_7hX`p  
9、存储更改全部表 @&jR^`Y.  
CREATE PROCEDURE dbo.User_ChangeObjectOwnerBatch \kE0h\  
@OldOwner as NVARCHAR(128), fTxd8an{  
@NewOwner as NVARCHAR(128) FB k7Cn!  
AS Q%CrB>|@  
DECLARE @Name  as NVARCHAR(128) Q Xd`P4a  
DECLARE @Owner  as NVARCHAR(128) }T_"Vg q  
DECLARE @OwnerName  as NVARCHAR(128) W ?x~"-*  
DECLARE curObject CURSOR FOR fh#:j[R4e  
select 'Name'  = name, #JUh"8N'  
  'Owner'  = user_name(uid) Tv%7=P;r  
from sysobjects T{prCM  
where user_name(uid)=@OldOwner | BaEv\$K  
order by name yY]x' 'K  
OPEN  curObject 0fc;H}B*  
FETCH NEXT FROM curObject INTO @Name, @Owner \Z.r Pq  
WHILE(@@FETCH_STATUS=0) @!;A^<{ka  
BEGIN    PqspoH 0OI  
if @Owner=@OldOwner 2)EqqX[D  
begin 73qE!(  
  set @OwnerName = @OldOwner + '.' + rtrim(@Name) QL0q/S1*  
  exec sp_changeobjectowner @OwnerName, @NewOwner 'a(y]QG  
end ;CO qu#(  
-- select @name,@NewOwner,@OldOwner F=\ REq  
FETCH NEXT FROM curObject INTO @Name, @Owner 8UB2 du@?  
END 'IU3Xu[-.  
close curObject jHEP1rNHE  
deallocate curObject `8ob Xb  
GO :E W1I>}_  
10、SQL SERVER中直接循环写入数据 RFM;?!S  
declare @i int + S+!:IB  
set @i=1  II'.vp  
while @i<30 65Z}Hf  
begin gX"  
  insert into test (userid) values(@i) 5Q"yn2b4  
  set @i=@i+1 c@A.jc  
end (-ELxshd  
小记存储过程中经常用到的本周,本月,本年函数 6+=_p$crMx  
Dateadd(wk,datediff(wk,0,getdate()),-1) !\b-Ot(  
Dateadd(wk,datediff(wk,0,getdate()),6) j32*9  
Dateadd(mm,datediff(mm,0,getdate()),0) p,=IL_  
Dateadd(ms,-3,dateadd(mm,datediff(m,0,getdate())+1,0)) kB+$Kt<]L  
Dateadd(yy,datediff(yy,0,getdate()),0) S6bW r0XR  
Dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0)) rL<N:@HL  
上面的SQL代码只是一个时间段 <ppdy,j:  
Dateadd(wk,datediff(wk,0,getdate()),-1) auI`'O`/  
Dateadd(wk,datediff(wk,0,getdate()),6) s<*+=aIfu  
就是表示本周时间段. e;v7!X  
下面的SQL的条件部分,就是查询时间段在本周范围内的: WOPIF~1v  
Where Time BETWEEN Dateadd(wk,datediff(wk,0,getdate()),-1) AND Dateadd(wk,datediff(wk,0,getdate()),6) , S^y>  
而在存储过程中 I(UK9H{0$  
select @begintime = Dateadd(wk,datediff(wk,0,getdate()),-1) Q``1^E'  
select @endtime = Dateadd(wk,datediff(wk,0,getdate()),6) OcB&6!1u  
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水

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

描述
快速回复

您目前还是游客,请 登录注册
如果您提交过一次失败了,可以用”恢复数据”来恢复帖子内容
认证码:
验证问题:
10+5=?,请输入中文答案:十五