欧美色欧美亚洲高清在线观看,国产特黄特色a级在线视频,国产一区视频一区欧美,亚洲成a 人在线观看中文

  1. <ul id="fwlom"></ul>

    <object id="fwlom"></object>

    <span id="fwlom"></span><dfn id="fwlom"></dfn>

      <object id="fwlom"></object>

      優(yōu)化SQL語句需要注意的4個要點

      時間:2019-05-12 20:35:00下載本文作者:會員上傳
      簡介:寫寫幫文庫小編為你整理了多篇相關(guān)的《優(yōu)化SQL語句需要注意的4個要點》,但愿對你工作學(xué)習(xí)有幫助,當(dāng)然你在寫寫幫文庫還可以找到更多《優(yōu)化SQL語句需要注意的4個要點》。

      第一篇:優(yōu)化SQL語句需要注意的4個要點

      1.盡量不要對列名進(jìn)行函數(shù)處理。而是針對后面的值進(jìn)行處理 例如where col1 =-5的效率比where-col1=5的效率要高

      因為后面的條件對列值進(jìn)行了計算。這樣的條件下優(yōu)化器無法使用索引 而是要針對所有值進(jìn)行計算之后才能再比較

      2.盡量使用和數(shù)劇列一樣的值進(jìn)行操作

      如果col1是數(shù)值型

      那么例如where col1 = 2和where col1= ‘2′

      則前者效率更高

      因為比較字符和數(shù)值型的時候

      引擎需要把兩者都轉(zhuǎn)化成雙精度然后進(jìn)行比較

      3.減少函數(shù)的使用

      例如where col1 >= ‘2009-10-26′ and col1 <= ‘2009-10-27′

      和where datediff(day,col1,getdate())=0

      后者因為用到函數(shù)處理。所以col1上的索引又無法使用了

      4.盡量不要用OR

      一般對于OR的條件

      優(yōu)化器一般會使用全表掃描

      第二篇:SQL語句性能優(yōu)化

      我也做了很長時間醫(yī)療軟件,也寫過不少sql優(yōu)化,沒有詳細(xì)記錄下來,個人感覺下面轉(zhuǎn)載的更符合醫(yī)院醫(yī)療軟件實際業(yè)務(wù),很認(rèn)可大部分所寫的原則,固轉(zhuǎn)載過來,以作借鑒。軟件的根本還是在于更細(xì)更精,在于從客戶的實際使用考慮問題。

      性能優(yōu)化原則1:永遠(yuǎn)避免困境

      利用緩存把字典數(shù)據(jù)取到中間服務(wù)器或是客戶端替代直接sql查詢,如,門診醫(yī)生站把字典下載到客戶端,減少執(zhí)行次數(shù)。

      一次性取數(shù)據(jù)到客戶端,然后再逐條處理,而不是分次取數(shù)據(jù),處理好一條數(shù)據(jù)再取下一條再處理。例:門診收費(fèi)取hjcfmxk例子,原來是一張?zhí)幏綏l明細(xì)都查詢一次,查詢后再處理,現(xiàn)改為一次把所有明細(xì)都取過來,然后一條條處理

      盡量減少光標(biāo),看能不能用臨時表

      性能優(yōu)化原則2:kiss原則

      對于where 條件中的左邊可以利用索引的字段Keep it simple stupid,左邊盡量避免用函數(shù)(substring,isnull,upper,lower),參加計算+,-*/

      例子1:select * from ZY_BRFYMXK where substring(zxrq,1,8)='20081212‘

      select * from ZY_BRFYMXK where zxrq between '2008121200' and '2008121224' 例子2:

      select * from zy_detail_charge where SUBSTRING(patient_id,1,10)=

      substring('000005090600',1,10)這句耗時30秒以上

      select * from zy_detail_charge where patient_id like substring('000005090600',1,10)+'%' 這句耗時2秒以內(nèi)

      性能優(yōu)化原則3:盡可能利用到索引

      例:select * from ZY_BRFYMXK a(nolock),VW_LSYZK b(nolock)where a.syxh=3 and a.yzxh=b.xh and a.fylb=0

      select * from ZY_BRFYMXK a(nolock),VW_LSYZK b(nolock)where a.syxh=3 and a.yzxh=b.xh and a.fylb=0 and b.syxh=3

      性能優(yōu)化原則4:or,避而遠(yuǎn)之

      對于索引字段盡力避免用or,普通字段可以用or,解決要么分解成多個sql,要么用業(yè)務(wù)規(guī)則避免,例:declare @rq1 ut_rq16,@syxh ut_syxh

      select @rq1='20081201'

      select @syxh=157

      性能優(yōu)化原則5:避免大批量數(shù)據(jù)取到前臺

      例: select * from ZY_BRSYK cyrq between ‘20080901’ and ‘20081201‘,對于大醫(yī)院每天100多人,90天是9000條數(shù)據(jù)

      性能優(yōu)化原則6:事務(wù),盡可能的短吧

      所有計算、對臨時表的更新都應(yīng)但放在事務(wù)外,事務(wù)中最好只有更新和插入正式表操作.因為事務(wù)中產(chǎn)生的鎖只有在commit tran是才會釋放。

      性能優(yōu)化原則7:熱表,留在最后吧

      熱表是頻繁調(diào)用的表。如:sf_mzcfk,zy_brfymxk,bq_fyqqk.對于熱表盡量放在事務(wù)最后:這樣鎖的時間短。大家都堅持這樣,死鎖的可能性就小。如果都是熱表各個存儲過程更新表的順序應(yīng)當(dāng)一樣這樣可以避免死鎖

      性能優(yōu)化原則8:創(chuàng)建臨時表一定要避免在事務(wù)中作

      如create #tempXX(…)

      Select * into #tempXX from …

      因為創(chuàng)建臨時表會鎖tempdb的系統(tǒng)表

      例:生成#temp1放在事務(wù)內(nèi)外,用sp_lock2 ‘’觀察結(jié)果

      if object_id('tempdb..#temp1','U')is not null

      drop table #temp1

      begin tran

      select * into #temp1 from ZY_BRSYK where ryrq>'20080901‘

      select * from #temp1

      waitfor delay '00:00:10'

      commit

      性能優(yōu)化原則9:大的報表查詢避免與正常業(yè)務(wù)碰撞

      如果沒有查詢服務(wù)器,那要在存儲過程中限制不能操作加上如:

      declare @rq1 ut_rq16,@rq2 ut_rq16,@now ut_rq16

      select @rq1=convert(varchar(8),getdate(),112)+'08:00:00'

      select @rq1=convert(varchar(8),getdate(),112)+'11:30:00'

      select @now=convert(char(8),getdate(),112)+convert(char(8),getdate(),8)

      if @now>@rq1 and @now<@rq2

      begin

      select '上午繁忙時間段不能作此查詢'

      return

      end

      性能優(yōu)化原則10:存儲過程避免大的if…else…

      這個常出項在業(yè)務(wù)相同表不同的存儲過程中,因為這樣常到if …else …原來醫(yī)技接口中很多這種存儲過程,當(dāng)時把門診住院業(yè)務(wù)放在一個存儲過程中。這樣最大的問題是sql server會根據(jù)sql語句來compile存儲,這個過程會生成優(yōu)化計劃,決定用那個索引。如果存儲過程用到門診表compile一下,到用到住院表是發(fā)現(xiàn)不對,又會compile一下,這樣不停compile.compile很號時間要1-2秒,而且一個存儲過成在compile是,所有調(diào)用這個存儲過程的進(jìn)程都要在排隊等候,因為他會獨(dú)占鎖這個存儲過程

      例:usp_yjjk_getwzxxm_old.sql,后改為:

      usp_yjjk_getwzxxm.sql, usp_yjjk_getwzxxm_mz.sql,usp_yjjk_getwzxxm_zy.sql

      性能優(yōu)化原則11:進(jìn)攻是最好的防守

      在普通編程語句對于數(shù)據(jù)校驗總是用防守辦法先判斷,后再作相應(yīng)處理。而在sql中先處理再判斷性能會好很多。

      --更新藥品庫存。

      If exists(select 1 from YK_YKZKC WHERE idm=100 and kcsl>50)

      begin

      update YK_YKZKC set kcsl=kcsl-50 where idm=100

      End

      Else begin

      rollback tran

      Select ‘F庫存不夠’

      return

      end

      --改為

      update YK_YKZKC set kcsl=kcsl-50 where idm=100 and kcsl>50

      If @@rowcount<=0

      Begin

      Rollbakc tran

      Select ‘F庫存不夠’

      end

      --取未執(zhí)行的醫(yī)技項目,日表沒有數(shù)據(jù)就到年表中查找

      if exists(select a.* from SF_MZCFK a(nolock),SF_CFMXK b(nolock)

      begin

      select a.* into #temp1 from SF_MZCFK a(nolock),SF_CFMXK b(nolock)

      end

      else begin

      select a.* into #temp1 from SF_NMZCFK a(nolock),SF_NCFMXK b(nolock)

      end

      --改為

      Insert into #temp1 select a.*

      from SF_MZCFK a(nolock),SF_CFMXK b(nolock)

      If @@rowcount=0

      Begin

      Insert into #temp1 select a.*

      from SF_NMZCFK a(nolock),SF_NCFMXK b(nolock)

      end

      性能優(yōu)化原則12:trig最后的手段

      Trig(觸發(fā)器)的處理的處理機(jī)制是滿足條件時就會在源語句后面加上trig中的代碼進(jìn)行執(zhí)行。

      它有兩個致命的弊端:(1)不清楚有trig的人會對于執(zhí)行結(jié)果感到迷惑。如常有在插入一張表如果主鍵是indentity的值常取用select @@identity。但如是有trig,tring中有表插入操作,這時的@@identity可能就不是想要的值。(2)trig會束縛選擇。如:有一套單據(jù)主表和明細(xì)表,當(dāng)明細(xì)表的金額更新時,要同步主表的金額,當(dāng)程序是一條條更新明細(xì)時用trig的作法是每當(dāng)更新一條明細(xì)記錄時都算一處所有明細(xì)表的總金額,再去更新主表的金額。這樣有多少條明細(xì)就要算多少次,好的作法是不要trig,直接在sql語句中明細(xì)更新完明后,一次性算出總金額每條單據(jù)的總金額,再更新主表的金額。

      對于trig如果有其他手段就一定要避免用trig.性能優(yōu)化原則13:用戶說好才是真的好

      1)有時sql語句性能難以優(yōu)化,但用戶對于系統(tǒng)響應(yīng)速度還是不滿意。這時可以從業(yè)務(wù)分析處理。

      如:我們退費(fèi)模塊錄入發(fā)票號原來是用fph like ‘XXX%’。用戶報怨慢,后來改為先用fph=‘XXX’來查,如查不到再fph like ‘XXX%’。這樣在絕大部情況下速度都非常快,同時也滿足小部分情況下模糊查詢的需求。

      如:我們的程序要查日表和年表。如果通過日表union表視圖去查會非常慢,性能也難以優(yōu)化。程序改為普通情況下不查年表,用戶勾上年表標(biāo)志時才查年表。

      (2)查詢統(tǒng)計很多數(shù)據(jù)時間比較長,就以查詢完一部分?jǐn)?shù)據(jù)后可以顯示這部分?jǐn)?shù)據(jù)或是用提示,這樣用戶清楚系統(tǒng)在作事情也知道大概進(jìn)度。這樣情緒上會好很多。

      (3)查詢模塊常有一進(jìn)入時也默認(rèn)一個查詢,如果性能好,查詢又合用戶心意,這種設(shè)計非常好,如果性能不好,那就不是好的設(shè)計。用戶對于進(jìn)入都困難的模塊是沒有好感的。

      (4)有戶的耐心與查詢出的記錄成正比。用戶痛恨等待很久卻沒有查詢出記錄。

      對于非常慢的查詢,如果有些子查詢非常快可以先作這樣查詢以避免查詢很久卻沒有數(shù)據(jù)出來的情況。如:按病歷號查在院病人所有費(fèi)有明細(xì),可以先查一下這個病歷是不是有對應(yīng)病人。

      實戰(zhàn)技巧1:用exists、in代替distinct

      Distinct實際上是先收集再刪除這樣兩步都耗資源。

      Exists,in會隱式過濾掉重復(fù)的記錄

      例查自2009年以來有金額大于100的藥品的病人

      select distinct a.blh,a.hzxm from ZY_BRXXK a(nolock),ZY_BRSYK b(nolock),ZY_BRFYMXK c(nolock)where a.patid=b.patid and b.syxh=c.syxh and c.zxrq>'2009' and c.zje>100--改為

      select a.blh,a.hzxm from ZY_BRXXK a where exists(select 1 from ZY_BRSYK

      b(nolock),ZY_BRFYMXK c(nolock)where a.patid=b.patid and b.syxh=c.syxh and

      c.zxrq>'2009'and c.zje>100)

      實戰(zhàn)技巧2:縮短union

      select …from A,B,C,D,E1

      where(E1的條件)

      and(其他表聯(lián)接條件)

      union

      select …from A,B,C,D,E2

      where(E2的條件)

      and(其他表接接條件)

      改為

      select …from A,B,C,D,(select...from E1where(E1條件)

      union

      select …from E2where(E2條件))E where(其他條件)

      當(dāng)涉及ABCD表部分耗資源而E1,E2不耗資源時是這樣,如果反過來則改后的性能不一定好。查2009年4月后入院的在院病人在2905病區(qū)發(fā)生的所有費(fèi)用明細(xì)

      select a.hzxm,b.cyrq,d.ypmc,d.ypgg,c.ypsl/c.dwxs ypsl, c.ypdw

      select a.hzxm,b.cyrq,d.ypmc,d.ypgg,c.ypsl/c.dwxs ypsl, c.ypdw

      from ZY_BRXXK a(nolock),ZY_BRSYK b(nolock),ZY_BRFYMXK c(nolock),YK_YPCDMLK d where a.patid=b.patid and b.ryrq>'200904' and b.brzt not in(3,8,9)and b.syxh=c.syxh and c.bqdm='2905' and c.idm=d.idm

      union all

      select a.hzxm,b.cyrq,d.name,d.xmgg,c.ypsl/c.dwxs ypsl, c.ypdw

      from ZY_BRXXK a(nolock),ZY_BRSYK b(nolock),ZY_BRFYMXK c(nolock),YY_SFXXMK d where a.patid=b.patid and b.ryrq>'200904' and b.brzt not in(3,8,9)and b.syxh=c.syxh and c.bqdm='2905' and c.ypdm=d.id and c.idm=0

      --改為

      select a.hzxm,b.cyrq,d.ypmc,d.ypgg,c.ypsl/c.dwxs ypsl, c.ypdw

      from ZY_BRXXK a(nolock),ZY_BRSYK b(nolock),ZY_BRFYMXK c(nolock),(select ypmc,ypgg,ypdm,idm idm from YK_YPCDMLK union select name,xmgg,id,0 from YY_SFXXMK)d

      where a.patid=b.patid and b.ryrq>'200904' and b.brzt not in(3,8,9)and b.syxh=c.syxh and c.bqdm='2905' and c.idm=d.idm and c.ypdm=d.ypdm

      實戰(zhàn)技巧3:合并sql

      把表和where條件類似的兩個或是多個sql合并為一個sql.--查2009年以后的普通、急診、專家掛號人數(shù)

      declare @ptghs int,@jzghs int,@zjghs int

      select @ptghs=0,@jzghs=0,@zjghs=0

      select @ptghs=count(*)from GH_GHZDK where ghrq>'2009' and ghlb=0

      select @jzghs=count(*)from GH_GHZDK where ghrq>'2009' and ghlb=1

      select @zjghs=count(*)from GH_GHZDK where ghrq>'2009' and ghlb=2

      select @ptghs,@jzghs,@zjghs

      --改為

      select @ptghs=0,@jzghs=0,@zjghs=0

      select @ptghs=sum(case when ghlb=0 then 1 else 0 end),@jzghs=sum(case when ghlb=1 then 1 else 0 end), @zjghs=sum(case when ghlb=2 then 1 else 0 end)

      from GH_GHZDK where ghrq>'2009'

      select @ptghs,@jzghs,@zjghs

      實戰(zhàn)技巧4:去掉游標(biāo)

      把游標(biāo)當(dāng)作編程語言的for,do---while的方式,很多情況下都可以去掉,如果光標(biāo)中間sql語句只有一條一般都是可以去掉光標(biāo)改為一句sql。

      --查當(dāng)天出院出院日期在2009年4月1到9日間病人的zfdj,zfje置為0

      declare @syxh ut_syxh

      declare cur1 cursor for select syxh from ZY_BRSYK where cyrq>='20090401' and cyrq<'20090410'

      open cur1

      fetch cur1 into @syxh

      while @@fetch_status=0

      begin

      fetch cur1 into @syxh

      end

      close cur1

      deallocate cur1

      --改為

      update ZY_BRFYMXK set zfdj=0,zfje=0

      from ZY_BRFYMXK a,ZY_BRSYK b

      where a.syxh=b.syxh and b.cyrq>='20090401' and b.cyrq<'20090410'

      實戰(zhàn)技巧5:取代count

      利用內(nèi)部函數(shù)代替

      declare @count int

      select * into #tmep1 from ZY_BRFYMXK WHERE zxrq>'200901'

      select @count=@@rowcount—可以得到count值

      select @count

      select @count=count(*)from #tmep1—可以被取代

      select @count

      利用exists而不count判斷有沒有記錄

      declare @count int

      Select @count=count(1)from ZY_BRFYMXK WHERE zxrq>'2009‘

      If @count>0 … else ….--改為

      If exists(Select 1 from ZY_BRFYMXK WHERE zxrq>'2009’)… else ….

      第三篇:SQL語句的優(yōu)化方法

      SQL語句的優(yōu)化方法

      1.1注釋使用

      在語句中多寫注釋,注釋不影響SQL語句的執(zhí)行效率。增加代碼的可讀性。

      1.2對于事務(wù)的使用

      盡量使事務(wù)處理達(dá)到最短,如果事務(wù)太長最好按功能將事務(wù)分開執(zhí)行(如:可以讓用戶在界面上多幾步操作)。事務(wù)太長很容易造成數(shù)據(jù)庫阻塞,用戶操作速度變慢或死機(jī)情況。

      1.3對于與數(shù)據(jù)庫的交互

      盡量減少與數(shù)據(jù)庫的交互次數(shù)。如果在前端程序?qū)懹醒蛟L問數(shù)據(jù)庫操作,最好寫成將數(shù)據(jù)一次讀到前端再進(jìn)行處理或者寫成存儲過程在數(shù)據(jù)庫端直接處理。

      1.4對于SELECT *這樣的語句,不要使用SELECT *這樣的語句,而應(yīng)該使用SELECT table1.column1這樣的語句,明確指出要查詢的列減少數(shù)據(jù)的通訊量并且這樣的代碼可讀性好,便于維護(hù)。

      1.5盡量避免使用游標(biāo)

      它占用大量的資源。如果需要row-by-row地執(zhí)行,盡量采用非光標(biāo)技術(shù),如:在客戶端循環(huán),用臨時表,Table變量,用子查詢,用Case語句等等。如果使用了游標(biāo),就要盡量避免在游標(biāo)循環(huán)中再進(jìn)行表連接的操作。

      1.6盡量使用count(1)

      count函數(shù)只有在統(tǒng)計表中所有行數(shù)時使用,而且count(1)比count(*)更有效率。

      1.7IN和EXISTS

      EXISTS要遠(yuǎn)比IN的效率高。里面關(guān)系到full table scan和range scan。幾乎將所有的IN操作符子查詢改寫為使用EXISTS的子查詢。

      1.8注意表之間連接的數(shù)據(jù)類型

      避免不同類型數(shù)據(jù)之間的連接。

      1.9盡量少用視圖

      對視圖操作比直接對表操作慢,可以用stored procedure來代替她。特別的是不要用視圖嵌套,嵌套視圖增加了尋找原始資料的難度。我們看視圖的本質(zhì):它是存放在服務(wù)器上的被優(yōu)化好了的已經(jīng)產(chǎn)生了查詢規(guī)劃的SQL。對單個表檢索數(shù)據(jù)時,不要使用指向多個表的視圖,直接從表檢索或者僅僅包含這個表的視圖上讀,否則增加了不必要的開銷,查詢受到干擾。

      1.10沒有必要時不要用DISTINCT和ORDER BY

      這些動作可以改在客戶端執(zhí)行,它們增加了額外的開銷。

      1.11避免相關(guān)子查詢

      一個列的標(biāo)簽同時在主查詢和where子句中的查詢中出現(xiàn),那么很可能當(dāng)主查詢中的列值改變之后,子查詢必須重新查詢一次。查詢嵌套層次越多,效率越低,因此應(yīng)當(dāng)盡量避免子查詢。如果子查詢不可避免,那么要在子查詢中過濾掉盡可能多的行。

      1.1注意UNion和`UNion all 的區(qū)別

      UNION all執(zhí)行效率高。

      1.1外鍵關(guān)聯(lián)的列應(yīng)該建立索引

      (如子表id)主子表單據(jù)肯定要建視圖,2個表的關(guān)聯(lián)以2個表中的MainID為關(guān)系,所以,需要給子表的MainID單獨(dú)建索引,這將很大地提高視圖的速度。例如Gy_InOutSub中的InoutMainid增加索引。

      第四篇:sql常用語句

      //創(chuàng)建臨時表空間

      create temporary tablespace test_temp

      tempfile 'E:oracleproduct10.2.0oradatatestservertest_temp01.dbf'size 32m

      autoextend on

      next 32m maxsize 2048m

      extent management local;

      //創(chuàng)建數(shù)據(jù)表空間

      create tablespace test_data

      logging

      datafile 'E:oracleproduct10.2.0oradatatestservertest_data01.dbf'size 32m

      autoextend on

      next 32m maxsize 2048m

      extent management local;

      //創(chuàng)建用戶并指定表空間

      create user username identified by password

      default tablespace test_data

      temporary tablespace test_temp;

      //給用戶授予權(quán)限

      //一般用戶

      grant connect,resource to username;

      //系統(tǒng)權(quán)限

      grant connect,dba,resource to username

      //創(chuàng)建用戶

      create user user01 identified by u01

      //建表

      create table test7272(id number(10),name varchar2(20),age number(4),joindate date default sysdate,primary key(id));

      //存儲過程

      //數(shù)據(jù)庫連接池

      數(shù)據(jù)庫連接池負(fù)責(zé)分配、管理和釋放數(shù)據(jù)庫連接

      //

      //創(chuàng)建表空間

      create tablespace thirdspace

      datafile 'C:/Program Files/Oracle/thirdspace.dbf' size 10mautoextend on;

      //創(chuàng)建用戶

      create user binbin

      identified by binbin

      default tablespace firstspace

      temporary tablespace temp;

      //賦予權(quán)限

      GRANT CONNECT, SYSDBA, RESOURCE to binbin

      //null與""的區(qū)別

      簡單點說null表示還沒new出對象,就是還沒開辟空間

      個對象裝的是空字符串。

      //建視圖

      create view viewname

      as

      sql

      //建索引

      create index indexname on tablename(columnname)

      //在表中增加一列

      alter table tablename add columnname columntype

      //刪除一列

      alter table tablename drop columnname

      //刪除表格內(nèi)容,表格結(jié)構(gòu)不變

      truncate table tableneme

      //新增數(shù)據(jù)

      insert into tablename()values()

      //直接新增多條數(shù)據(jù)

      insert into tablename()

      selecte a,b,c

      from tableabc

      //更新數(shù)據(jù) new除了對象,但是這“”表示

      update tablename set columnname=? where

      //刪除數(shù)據(jù)

      delete from tablename

      where

      //union語句

      sql

      union

      sql

      //case

      case

      when then

      else

      end

      第五篇:SQL語句

      SQL練習(xí)

      一、設(shè)有如下的關(guān)系模式,試用SQL語句完成以下操作:

      學(xué)生(學(xué)號,姓名,性別,年齡,所在系)

      課程(課程號,課程名,學(xué)分,學(xué)期,學(xué)時)

      選課(學(xué)號,課程號,成績)

      1. 求選修了課程號為“C2”課的學(xué)生學(xué)號

      2. 求選修了課程號為“C2”課的學(xué)生學(xué)號和姓名

      3. 求沒有選修課程號為“C2”課的學(xué)生學(xué)號

      4. 求選修了課程號為“C2”,又選修了課程號為“C3”課的學(xué)生學(xué)號

      5.求選修了課程號為“C2”或“C3”課的學(xué)生學(xué)號

      6.求選修了全部課程的學(xué)生學(xué)號

      7.求至少選修了學(xué)號為“98002”的學(xué)生所學(xué)過的所有課程的學(xué)生的學(xué)號和姓名。

      8.查詢學(xué)生選課表中的全部數(shù)據(jù)

      9.查詢計算機(jī)系學(xué)生的姓名、年齡

      10.查詢成績在70—80分之間的學(xué)生的學(xué)號、課程號和成績

      11.查詢計算機(jī)系年齡在18—20之間且性別為“男”的學(xué)生的姓名和年齡

      12.查詢成績在80分以上的學(xué)生的姓名、課程號和成績,并按成績的降序排列結(jié)果。

      13.查詢哪些課程沒有人選修,要求列出課程號和課程名。

      14.查詢數(shù)學(xué)系成績在80分以上的學(xué)生的學(xué)號,姓名

      15.查詢課程號為“C02”的課程的最高分?jǐn)?shù)。

      16.查詢計算機(jī)系學(xué)生的最大年齡和最小年齡。

      17.統(tǒng)計每個系的學(xué)生人數(shù)。

      18.統(tǒng)計每門課程的選課人數(shù)和考試最高分。

      19.統(tǒng)計每個學(xué)生的選課門數(shù)和考試總成績,并按選課門數(shù)的升序顯示結(jié)果。

      20.查詢總成績超過200分的學(xué)生,要求列出學(xué)號、總成績。

      21.用子查詢實現(xiàn)如下查詢:

      (1)查詢選修了課程號“C01”的學(xué)生的姓名和所在系。

      (2)查詢數(shù)學(xué)系成績在80分以上的學(xué)生的學(xué)號和姓名。

      (3)查詢計算機(jī)系考試成績最高的學(xué)生的姓名。

      22.刪除選課成績小于60分的學(xué)生的選課記錄。

      23.將所有選修了課程“C01”的學(xué)生的成績加10分。

      24.將計算機(jī)系所有選修了課程“計算機(jī)文化基礎(chǔ)”課程的學(xué)生的成績加10分。

      25.創(chuàng)建查詢學(xué)生的學(xué)號、姓名、所在系、課程號、課程名、課程學(xué)分的視圖。

      26.創(chuàng)建查詢每個學(xué)生的平均成績的視圖,要求列出學(xué)生學(xué)號和平均成績。

      27.創(chuàng)建查詢每個學(xué)生的選課學(xué)分的視圖,要求列出學(xué)生學(xué)號及總學(xué)分。

      下載優(yōu)化SQL語句需要注意的4個要點word格式文檔
      下載優(yōu)化SQL語句需要注意的4個要點.doc
      將本文檔下載到自己電腦,方便修改和收藏,請勿使用迅雷等下載。
      點此處下載文檔

      文檔為doc格式


      聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻(xiàn)自行上傳,本網(wǎng)站不擁有所有權(quán),未作人工編輯處理,也不承擔(dān)相關(guān)法律責(zé)任。如果您發(fā)現(xiàn)有涉嫌版權(quán)的內(nèi)容,歡迎發(fā)送郵件至:645879355@qq.com 進(jìn)行舉報,并提供相關(guān)證據(jù),工作人員會在5個工作日內(nèi)聯(lián)系你,一經(jīng)查實,本站將立刻刪除涉嫌侵權(quán)內(nèi)容。

      相關(guān)范文推薦

        SQL語句

        SQL語句,用友的SQL2000,通過查詢管理器寫的語句 1、查詢 2、修改 3、刪除 4、插入表名:users 包含字段:id,sname,sage 查詢 select * from users查詢users表中所有數(shù)據(jù) select i......

        常用SQL語句

        一、創(chuàng)建數(shù)據(jù)庫 create database 數(shù)據(jù)庫名 on( name='數(shù)據(jù)庫名_data', size='數(shù)據(jù)庫文件大小', maxsize='數(shù)據(jù)庫文件最大值', filegrowth=5%,//數(shù)據(jù)庫文件的增長率 filename......

        sql語句

        簡單基本的sql語句 幾個簡單的基本的sql語句 選擇:select * from table1 where范圍 插入:insert into table1(field1,field2) values(value1,value2) 刪除:delete from table1......

        常用sql語句

        1、查看表空間的名稱及大小 select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_size from dba_tablespaces t, dba_data_files d where t.tablespace_name = d......

        SQL優(yōu)化要點總結(jié)(共5篇)

        SQL優(yōu)化要點總結(jié) 文章比較簡短,但很實用,SQL優(yōu)化要點總結(jié): 1、盡量避免大表的全表掃描,建立合適的索引,務(wù)必注意索引是把雙刃劍,不能濫用,用好則已,用不好傷人害已。 2、能不......

        簡單SQL語句小結(jié)

        簡單SQL語句小結(jié) 注釋:本文假定已經(jīng)建立了一個學(xué)生成績管理數(shù)據(jù)庫,全文均以學(xué)生成績的管理為例來描述。 1.在查詢結(jié)果中顯示列名: a. 用as關(guān)鍵字:select name as '姓名' from s......

        常用SQL語句(最終五篇)

        查詢:select * from table1 where 范圍 select * from table where table001='JSBQF050' and table002='1307050002' and table003='0020' and table004='0030' select * fro......

        sql語句學(xué)習(xí)

        一、選擇題 1、SQL語言是語言?!⊿QL特點)(易) A)層次數(shù)據(jù)庫 B)網(wǎng)絡(luò)數(shù)據(jù)庫 C)關(guān)系數(shù)據(jù)庫D)非數(shù)據(jù)庫 答案:C 2、SQL語言具有兩種使用方式,分別稱為交互式SQL和。 ——(SQL語言使......