溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

SQL SERVER基礎(chǔ)語(yǔ)法有哪些

發(fā)布時(shí)間:2021-11-25 10:55:10 來(lái)源:億速云 閱讀:139 作者:小新 欄目:數(shù)據(jù)庫(kù)

這篇文章主要介紹SQL SERVER基礎(chǔ)語(yǔ)法有哪些,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

Struct Query Language

1.3NF

  a.原子性

  b.不能數(shù)據(jù)冗余

  c.引用其他表的主鍵

2.約束

  a.非空約束

  b.主鍵約束

  c.唯一約束

  d.默認(rèn)約束

  e.檢查約束

  f.外鍵約束

3.外鍵與關(guān)系

  外鍵是約束,不做外鍵處理,關(guān)系也是存在的.

4.char varchar nchar nvarchar

  char:是固定字符,如果不夠,會(huì)用空格來(lái)處理. 不需要計(jì)算長(zhǎng)度,速度快.

  varchar:是動(dòng)態(tài)的大小.需要計(jì)算長(zhǎng)度,速度慢,存儲(chǔ)占用小.

  nvarchar:是以u(píng)nicode編碼存儲(chǔ).每個(gè)字符占2個(gè)字節(jié).可以在任何sql server都能正常顯示中文.不帶n的英文占1個(gè)字節(jié).中文占2個(gè)字節(jié)

5.crud

  [select]:

  取前5:select top 5

  取前5%:select top 5 percent

  去除重復(fù):select distinct

  條件:select * from 表名 where

  [insert]:insert into 表名[(字段名,字段名)] values(字段值,字段值)

  [update]:update 表名 set 字段名=字段值 [where]

  [delete]:delete [from] 表名 [where]

6.運(yùn)算符優(yōu)先級(jí)

  [邏輯運(yùn)算符]: and or not(!)

  [比較運(yùn)算符]:< > = !=

  比較運(yùn)算符一般邏輯運(yùn)算符優(yōu)先級(jí)要高,除了not.!只比小括號(hào)的優(yōu)先級(jí)低.

7.模糊查詢(xún)

  like:select * from 表名 where 字段名 like 值

  _:匹配任意一個(gè)字符

  %:匹配任意多個(gè)字符

  [%]:匹配字符%

8.空值處理

  ISNULL:select ISNULL(english,'缺考') from Scroe 英語(yǔ)成績(jī)?yōu)榭談t顯示缺考

  is [not] null:select * from Scroe where english is null 把英語(yǔ)成績(jī)?yōu)閚ull的查詢(xún)出來(lái)

9.聚合函數(shù)

  SUM AVG COUNT MAX MIN

  聚合函數(shù)一般和group by配合使用,having可以對(duì)group by后再過(guò)濾

10.完整查詢(xún)語(yǔ)句順序

  select top 5 distinct * from T where field = fieldValue group by field2 having field2>5 order by field

  1:from T  2:*  3:where  4:distinct  5:group by field2  6:having field2>5  7:order by  8:top 5

11.常用函數(shù)

  [類(lèi)型轉(zhuǎn)換]:CAST(值 as 類(lèi)型)  CONVERT(類(lèi)型,值)

  [字符串]:LTRIM(值)  RTRIM(值)  LOWER(值)  UPPER(值)  LEN(值)  SUBSTRING(值,開(kāi)始位置,長(zhǎng)度)

  [日期]:GETDATE()取現(xiàn)在時(shí)間  DATEADD(datepart,number,date)加時(shí)間date+num  DATEDIFF(datepart,startdate,enddate)取時(shí)間差end-start  DATEPART(datepart,date)

取消/強(qiáng)制插入標(biāo)識(shí)列:set identity_insert 表名 off/on

清空表:truncate table 表名

12.復(fù)制表

   select * into 新表 from 原表 where 1=1

13.聯(lián)合查詢(xún)

  當(dāng)2個(gè)結(jié)果集列數(shù)相同,類(lèi)型相同,可以合并為一個(gè)結(jié)果集.

  union:會(huì)自動(dòng)去除重復(fù)行

  union all:顯示所有行.

14.連接查詢(xún)

  分內(nèi)連接和外連接

  內(nèi)連接:[inner ]join

      select * from T1 inner join T2 on T1.ID2 = T2.ID

      自連接是特殊的內(nèi)連接,樹(shù)結(jié)構(gòu)存儲(chǔ): select * from T as T1 join T as T2 where T2.PID = T1.ID

  外連接:

    left [outer] join:左連接,左表內(nèi)容全部顯示.右邊沒(méi)有的用NULL標(biāo)示

    right [outer] join:右連接,右表內(nèi)容全部顯示.左邊沒(méi)有的用NULL標(biāo)示

    full [outer] join:全連接,左右表內(nèi)容全部顯示,沒(méi)有的用NULL標(biāo)示

15.開(kāi)窗函數(shù)

  可以將多行合并為一個(gè)區(qū)來(lái)看待.可以對(duì)一個(gè)區(qū)進(jìn)行統(tǒng)計(jì).區(qū)別于group by,可以查詢(xún)所有列.

  開(kāi)窗函數(shù):over()  里面可以跟order by和partition by(類(lèi)似 group by)

  排名:rank() over(order by id)

  排序:row_number() over(order by id)

  小計(jì):avg(cost) over(partition by cost)(平均費(fèi)用)

16.視圖

  本質(zhì)封裝一個(gè)sql語(yǔ)句,不會(huì)存儲(chǔ)任何數(shù)據(jù).

  創(chuàng)建:  create view viewName as sql語(yǔ)句

  查看sql:  exec sp_helptext viewName 

17.事務(wù)

  事務(wù)是保證多個(gè)操作同時(shí)成功或者同時(shí)失敗

  begin tran(開(kāi)始事務(wù))  commit tran(提交事務(wù))  rollback tran(回滾事務(wù))

  打開(kāi)/關(guān)閉事務(wù)自動(dòng)提交:set implicit_transactions off/on

18.存儲(chǔ)過(guò)程

  存儲(chǔ)過(guò)程本質(zhì)是封裝一段代碼.

  創(chuàng)建:  create proc procName  

        @param1 int,@param2 int output

        as  

        set  @param2 =@param1 * @param1 

  參數(shù)默認(rèn)值:存儲(chǔ)過(guò)程只有最后一個(gè)參數(shù)可以有默認(rèn)值.

19.索引

  [聚焦索引]:

  [非聚焦索引]:

  create index indexName on tableName(fieldName)

20.觸發(fā)器

  對(duì)某個(gè)表的進(jìn)行增刪改操作時(shí),自動(dòng)執(zhí)行一個(gè)操作.有2種方式執(zhí)行,1是觸發(fā)源操作前替換執(zhí)行 2是觸發(fā)源操作后執(zhí)行

  臨時(shí)表:inserted deleted

  2種方式:after | instead of

  3種觸發(fā)源:insert update delete

  創(chuàng)建:

    create trigger triggerName

      after insert

      as  begin

      insert into T  select * from inserted

      end

  建議:影響效率 謹(jǐn)慎使用

21.游標(biāo)

  逐行的操作數(shù)據(jù)

  對(duì)每條數(shù)據(jù)執(zhí)行指定的

  使用:(讓T表中每個(gè)人的年齡增1)

    declare c1 cursor for

    select id,age from T

    declare @id int

    declare @age int

    open c1

    fetch c1 into @id,@age

    while(@@FETCH_STATU = 0)

    begin

      set @age= 1 + @age

      update T set age = @age where id = @id

      fetch c1 into @id,@age

    end  

    close c1

    deallocate c1

以上是“SQL SERVER基礎(chǔ)語(yǔ)法有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI