數(shù)據(jù)庫基本SQL語句大全_第1頁
數(shù)據(jù)庫基本SQL語句大全_第2頁
數(shù)據(jù)庫基本SQL語句大全_第3頁
數(shù)據(jù)庫基本SQL語句大全_第4頁
數(shù)據(jù)庫基本SQL語句大全_第5頁
已閱讀5頁,還剩9頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、數(shù)據(jù)庫基本SQL語句大全數(shù)據(jù)庫基本-SQL語句大全| 一、基礎(chǔ)1、說明:創(chuàng)建數(shù)據(jù)庫Create DATABASE database-n ame2、說明:刪除數(shù)據(jù)庫drop database dbn ame3、說明:備份sql server-創(chuàng)建備份數(shù)據(jù)的deviceUSE masterEXEC sp_addumpdevice disk, testBack, c:mssql7backupMyNw in d_1.dat匸I -開始備份BACKUP DATABASE pubs TO testBack4、說明:創(chuàng)建新表一 create table tabname(col1 typel notnull

2、primary key,col2 type2 not根據(jù)已有的表創(chuàng)建新表:A : create table tab_new like tab_old ( 使用舊表創(chuàng)建新表 )B : create table tab_new as select col1,col2 from tab_old definition only專業(yè)word可編輯,唯一能改變的是增加va的語法很精妙,查資料!5、說明:刪除新表drop table tab name6、說明:增加一個列Alter table tab name add colum n col type注:列增加后將不能刪除。DB2中列加上后數(shù)據(jù)類型也不能改變

3、 rchar類型的長度。7、說明: 添加主鍵 : Alter table tab name add primary key(col) 說明: 刪除主鍵 : Alter table tab name drop primary key(col)8、說明:倉U建索弓丨:create unique index idxname on tabname(col 刪除索引 :drop index idxname注:索引是不可更改的,想更改必須刪除重新建。_ 9、說明:創(chuàng)建視圖:create view view name as select stateme nt 一 刪除視圖:drop view view na

4、me10、說明:幾個簡單的基本的sql語句一 選擇:select * from tablei where 范圍插入:insert into table1(field1,field2) values(value1,value2)刪除:delete from tablei where 范圍一 更新:update tablei set field1=value1 where 范圍一 查找:select * from tablei where fieldi like%value1% -like排序:select * from tablei order by fieldi,field2 desc總數(shù):s

5、elect cou ntas totalcou nt from table1求和:select sum(field1)as sumvalue from table1平均:select avg(field1)as avgvalue from table1最大:select max(field1)as maxvalue from table1最?。簊elect mi n(field1)as min value from table111、說明:幾個高級查詢運算詞A : UNION運算符UNION 運算符通過組合其他兩個結(jié)果表(例如TABLE1和TABLE2 )并消去表中任何重復(fù)行而派生岀一個結(jié)果表

6、 。當(dāng)ALL隨UNION 一起使用時(即UNION ALL ),不消除重復(fù)行。兩種情況下,派生表的每一行不是來自TABLE1就是來自TABLE2。B : EXCEPT運算符EXCEPT運算符通過包括所有在 TABLE1中但不在TABLE2中的行并消除所有重復(fù)行而派 生岀一個結(jié)果表。當(dāng)ALL隨EXCEPT 一起使用時(EXCEPT ALL),不消除重復(fù)行。C : INTERSECT 運算符L INTERSECT運算符通過只包括 TABLE1和TABLE2中都有的行并消除所有重復(fù)行而派生岀一個結(jié)果表。當(dāng)ALL隨INTERSECT 起使用時(INTERSECT ALL),不消除重復(fù)行。注:使用運算詞

7、的幾個查詢結(jié)果行必須是一致的。12、說明:使用外連接一 A、left outer join :左外連接(左連接):結(jié)果集幾包括連接表的匹配行,也包括左連接表的所有行。SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.cB : right outer join:右外連接(右連接):結(jié)果集既包括連接表的匹配連接行,也包括右連接表的所有行C : full outer join :全外連接:不僅包括符號連接表的匹配行,還包括兩個連接表中的所有記錄。二、提升1、說明:復(fù)制表(只復(fù)制結(jié)構(gòu),源表名:a新表名:

8、b) (Access可用)法一 :select * into b from a where 11法二:select top 0 * into b from a匚2、說明:拷貝表(拷貝數(shù)據(jù),源表名:a目標表名:b) (Access可用)in sert into b(a, b, c) select d,e,f from b;3、說明:跨數(shù)據(jù)庫之間表的拷貝(具體數(shù)據(jù)使用絕對路徑)(Access可用)insert into b(a, b, c) select d,e,f from bin 具體數(shù)據(jù)庫 where 條件例子:.from b in &Server.MapPath(.&data.mdb &

9、where.4、說明:子查詢(表名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)5、說明:顯示文章、提交人和最后回復(fù)時間select a.title,a.user name,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b6、說明:外連接查詢(表名1 : a表名2: b)select a.a, a.b, a.

10、c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c7、說明:在線視圖查詢(表名1 : aselect * from (Select a,b,c FROM a) T where t.a 1;不包8、 說明:between的用法,between限制查詢數(shù)據(jù)范圍時包括了邊界值,not between括select * from tablei where time between timel and time2select a,b,c, from tablei where a not between數(shù)值 1 and 數(shù)值 29、說明:in的使用方法

11、select * from table1 where a notin (值 1 :值 2,值 4值 6 10、說明:兩張關(guān)聯(lián)表,刪除主表中已經(jīng)在副表中沒有的信息delete from table1 where not exists ( select * from table2 where table1.field1=table2.field111、說明:四表聯(lián)查問題: 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 .12、說明:日程

12、安排提前五分鐘提醒select * from 日程安排 where datediff(minute,f開始時間,getdate()513、說明:一條sql語句搞定數(shù)據(jù)庫分頁select top 10 b.* from (select top 20主鍵字段,排序字段 from 表名 order by 排序字段desc) a,表名b where b.主鍵字段=a.主鍵字段order by a.排序字段14、說明:前10條記錄select top 10 * form table1 where范圍15、 說明:選擇在每一組b值相同的數(shù)據(jù)中對應(yīng)的 a最大的記錄的所有信息(類似這樣的用法可以用于論壇每月排

13、行榜,每月熱銷產(chǎn)品分析,按科目成績排名,等等.)select a,b,c from table name ta where a=(select max(a) from table name tb where tb.b=ta.b)l_ 16、說明:包括所有在 TableA中但不在TableB和TableC中的行并消除所有重復(fù)行而派 生出一個結(jié)果表(select a from tableA except (select a from tableB) except (select a from tableC)匸17、說明:隨機取岀10條數(shù)據(jù)一 select top 10 * from table n

14、ame order by n ewid()18、說明:隨機選擇記錄一 select n ewid()19、說明:刪除重復(fù)記錄一 Delete from table name where id notin (select max(id) from table name group by col1,col2,)20、說明:列岀數(shù)據(jù)庫里所有的表名select n ame from sysobjects where type=U21、說明:列岀表里的所有的select n ame from syscolu mns where id=object_id(TableName)22、說明:列示type、ve

15、nder、pcs字段,以type字段排列,case可以方便地實現(xiàn)多重選擇,類似select中的case。else 0 end),sum( case vender when Cselect type,sum( case ven der whe n A the n pcsthen pcs else 0 end),sum( case vender when B then pcs else 0 end)FROM table name group by type匚I顯示結(jié)果:type ven der pcs 電腦A 1電腦A 1光盤B 2L 光盤A 2I 手機B 3手機C 323、說明:初始化表tabl

16、eiTRUNCATE TABLE tablei24、說明:選擇從10到15的記錄另V名 order by iselect top 5 * from (select top 15 * from table order by id asc) table_ d desc三、技巧1、1=1 , 1=2的使用,在SQL語句組合時用的較多where仁1 ”是表示選擇全部where仁2 全部不選,如:if strWhere !=beginset strSQL = select cou nt(*) as Total from + tblName + where + strWhere一 endelsebegin

17、一set strSQL = select cou nt(*) as Total from + tblName + end我們可以直接寫成安定set strSQL = select count(*) as Total from + tblName + where 1=1 + strWhere2、收縮數(shù)據(jù)庫-重建索引DBCC REINDEXDBCC INDEXDEFRAG-收縮數(shù)據(jù)和日志DBCC SHRINKDBDBCC SHRINKFILE3、壓縮數(shù)據(jù)庫dbcc shri nkdatabase(db name)4、轉(zhuǎn)移數(shù)據(jù)庫給新用戶以已存在用戶權(quán)限exec sp_cha nge_users_lo

18、g in update_ on e, newn ame,old namego5、檢查備份集RESTORE VERIFYONLY from disk=E:dvbbs.bak6、修復(fù)數(shù)據(jù)庫Alter DATABASE dvbbs SET SINGLE_USERGODBCC CHECKDB(dvbbs,repair_allow_data_loss) WITH TABLOCKGOAlter DATABASE dvbbs SET MULTI_USERGO7、日志清除SET NOCOUNT ONDECLARE LogicalFileName sys name,MaxMi nutes INT,NewSize

19、 INTUSE table name-要操作的數(shù)據(jù)庫名Select LogicalFileName = table name_log,-日志文件名MaxM in utes = 10,- Limit on time allowed to wrap log.(M)NewSize = 1-你想設(shè)定的日志文件的大小-Setup / i nitialize一 DECLARE Origi nalSizeintSelect Origi nalSize = sizeFROM sysfiles一 Where n ame = LogicalFileNameSelect Original Size of + db_

20、name() + LOG is +CONVERT(VARCHAR(30),Origi nalSize) + 8K pages or +CONVERT(VARCHAR(30),(Origi nalSize*8/1024) + MB一 FROM sysfilesWhere n ame = LogicalFileNameCreate TABLE DummyTra ns(DummyColumn char (8000) not null )DECLARE Cou nter INT,StartTime DATETIME,Tru ncLog VARCHAR(255)Select StartTime = GE

21、TDATE(),Tru ncLog = BACKUP LOG + db_n ame() + WITH TRUNCATE_ONLYDBCC SHRINKFILE (LogicalFileName, NewSize)EXEC (Tru ncLog)-Wrap the log if n ecessary.WHILE MaxMi nutes DATEDIFF (mi, StartTime, GETDATE() - time has n ot ex piredAND Origi nalSize = (Select size FROM sysfiles Where name = LogicalFileNa

22、me)一 AND (Origi nalSize * 8 /1024) NewSize一 BEGIN - Outer loop.Select Cou nter = 0WHILE (Cou nter Origi nalSize / 16) AND (Cou nter 50000)一 BEGIN - update一In sert DummyTra ns VALUES (Fill Log)Delete DummyTra nsSelect Cou nter = Cou nter + 1ENDEXEC (Tru ncLog)ENDSelect Final Size of + db_name() + LOG is +CONVERT(VARCHAR(30),size) + 8K pages or +CONVERT(VARCHAR(30),(size*8/1024) + MBFROM sysfilesWhere n ame = LogicalFileNameDrop TABLE DummyTra nsSET NOCOUNT OFFL 8、說明:更改某個表exec sp_cha ngeobjectow ner table name,dbo9、存儲更改全部

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論