日本好好热aⅴ|国产99视频精品免费观看|日本成人aV在线|久热香蕉国产在线

  • <cite id="ikgdy"><table id="ikgdy"></table></cite>
    1. 西西軟件園多重安全檢測(cè)下載網(wǎng)站、值得信賴的軟件下載站!
      軟件
      軟件
      文章
      搜索

      首頁(yè)西西教程數(shù)據(jù)庫(kù)教程 → 數(shù)據(jù)庫(kù)語(yǔ)法從基礎(chǔ)到精通

      數(shù)據(jù)庫(kù)語(yǔ)法從基礎(chǔ)到精通

      相關(guān)軟件相關(guān)文章發(fā)表評(píng)論 來(lái)源:本站整理時(shí)間:2010/9/3 11:03:23字體大。A-A+

      作者:佚名點(diǎn)擊:1196次評(píng)論:0次標(biāo)簽: 數(shù)據(jù)庫(kù)

      • 類型:辦公軟件大。35KB語(yǔ)言:中文 評(píng)分:1.2
      • 標(biāo)簽:
      立即下載
      4 頁(yè) 精妙Sql語(yǔ)句

      精妙Sql語(yǔ)句
      1. 判斷a表中有而b表中沒(méi)有的記錄

      select a.* from tbl1 a

      left join tbl2 b

      on a.key = b.key

      where b.key is null

      雖然使用in也可以實(shí)現(xiàn),但是這種方法的效率更高一些

      2. 新建一個(gè)與某個(gè)表相同結(jié)構(gòu)的表

      select * into b

      from a where 1<>1

      3.between的用法,between限制查詢數(shù)據(jù)范圍時(shí)包括了邊界值,not between不包括

      select * from table1 where time between time1 and time2

      select a,b,c, from table1 where a not between 數(shù)值1 and 數(shù)值2

      4. 說(shuō)明:包括所有在 TableA 中但不在 TableB和TableC 中的行并消除所有重復(fù)行而派生出一個(gè)結(jié)果表

      (select a from tableA ) except (select a from tableB) except (select a from tableC)

      5. 初始化表,可以將自增長(zhǎng)表的字增長(zhǎng)字段置為1

      TRUNCATE TABLE table1

      6.多語(yǔ)言設(shè)置數(shù)據(jù)庫(kù)或者表或者order by的排序規(guī)則

      --修改用戶數(shù)據(jù)庫(kù)的排序規(guī)則

      ater database dbname collate SQL_Latin1_General_CP1_CI_AS

      --修改字段的排序規(guī)則

      alter table a alter column c2 varchar(50) collate SQL_Latin1_General_CP1_CI_AS

      --按姓氏筆畫(huà)排序

      select * from 表名 order by 列名 Collate Chinese_PRC_Stroke_ci_as

      --按拼音首字母排序

      select * from 表名 order by 列名 Collate Chinese_PRC_CS_AS_KS_WS

      7.列出所有的用戶數(shù)據(jù)表:

      SELECT TOP 100 PERCENT o.name AS 表名

      FROM dbo.syscolumns c INNER JOIN

      dbo.sysobjects o ON o.id = c.id AND objectproperty(o.id, N'IsUserTable') = 1 AND

      o.name <> 'dtproperties' LEFT OUTER JOIN

      dbo.sysproperties m ON m.id = o.id AND m.smallid = c.colorder

      WHERE (c.colid = 1)

      ORDER BY o.name, c.colid

       

      8.列出所有的用戶數(shù)據(jù)表及其字段信息:

      SELECT TOP 100 PERCENT c.colid AS 序號(hào), o.name AS 表名, c.name AS 列名,

      t.name AS 類型, c.length AS 長(zhǎng)度, c.isnullable AS 允許空,

      CAST(m.[value] AS Varchar(100)) AS 說(shuō)明

      FROM dbo.syscolumns c INNER JOIN

      dbo.sysobjects o ON o.id = c.id AND objectproperty(o.id, N'IsUserTable') = 1 AND

      o.name <> 'dtproperties' INNER JOIN

      dbo.systypes t ON t.xusertype = c.xusertype LEFT OUTER JOIN

      dbo.sysproperties m ON m.id = o.id AND m.smallid = c.colorder

      ORDER BY o.name, c.colid

      9.Left,right Join的另外一種簡(jiǎn)潔的寫(xiě)法

      select * from a,b where a.id *= b.id --(*= 相當(dāng)于 LEFT JOIN)

      select * from a,b where a.id =* b.id --(=* 相當(dāng)于 Right JOIN)

      10.Update from 和 delete from

      11.得到表中最小的未使用的ID號(hào)

      SELECT (CASE WHEN EXISTS(SELECT * FROM Handle b WHERE b.HandleID = 1)

      THEN MIN(HandleID) + 1 ELSE 1 END) as HandleID

      FROM Handle

      WHERE NOT HandleID IN (SELECT a.HandleID - 1 FROM Handle a)

      12.隨機(jī)取得記錄

      SELECT TOP 10 * FROM T1 ORDER BY NEWID()


      精妙SQL語(yǔ)句介紹

        如何從一位菜鳥(niǎo)蛻變成為高手,靈活使用的SQL語(yǔ)句是必不可少的。本文收集了部分比較經(jīng)典,常用的SQL語(yǔ)句供大家參考,希望對(duì)大家有所幫助。

        說(shuō)明:復(fù)制表(只復(fù)制結(jié)構(gòu),源表名:a 新表名:b)  

        SQL: select * into b from a where 1<>1

        說(shuō)明:拷貝表(拷貝數(shù)據(jù),源表名:a 目標(biāo)表名:b)  

        SQL: insert into b(a, b, c) select d,e,f from b;

        說(shuō)明:顯示文章、提交人和最后回復(fù)時(shí)間  

        SQL: select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b

        說(shuō)明:外連接查詢(表名1:a 表名2:b)  

        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

        說(shuō)明:日程安排提前五分鐘提醒  

        SQL: select * from 日程安排 where datediff('minute',f開(kāi)始時(shí)間,getdate())>5  

        說(shuō)明:兩張關(guān)聯(lián)表,刪除主表中已經(jīng)在副表中沒(méi)有的信息

        SQL:   

        delete from info where not exists ( select * from infobz where info.infid=infobz.infid

        說(shuō)明:--

        SQL:   

        SELECT A.NUM, A.NAME, B.UPD_DATE, B.PREV_UPD_DATE

         FROM TABLE1,

         (SELECT X.NUM, X.UPD_DATE, Y.UPD_DATE PREV_UPD_DATE

         FROM (SELECT NUM, UPD_DATE, INBOUND_QTY, STOCK_ONHAND

         FROM TABLE2

         WHERE TO_CHAR(UPD_DATE,'YYYY/MM') = TO_CHAR(SYSDATE, 'YYYY/MM')) X,

         (SELECT NUM, UPD_DATE, STOCK_ONHAND

         FROM TABLE2

         WHERE TO_CHAR(UPD_DATE,'YYYY/MM') =

         TO_CHAR(TO_DATE(TO_CHAR(SYSDATE, 'YYYY/MM') || '/01','YYYY/MM/DD') - 1, 'YYYY/MM') Y,

         WHERE X.NUM = Y.NUM (+)

         AND X.INBOUND_QTY + NVL(Y.STOCK_ONHAND,0) <> X.STOCK_ONHAND B

        WHERE A.NUM = B.NUM

        說(shuō)明:--

        SQL:   

        select * from studentinfo where not exists(select * from student where studentinfo.id=student.id) and 系名稱='"&strdepartmentname&"' and 專業(yè)名稱='"&strprofessionname&"' order by 性別,生源地,高考總成績(jī)

        說(shuō)明:

        從數(shù)據(jù)庫(kù)中去一年的各單位電話費(fèi)統(tǒng)計(jì)(電話費(fèi)定額賀電化肥清單兩個(gè)表來(lái)源)

        SQL:  

        SELECT a.userper, a.tel, a.standfee, TO_CHAR(a.telfeedate, 'yyyy') AS telyear,

         SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '01', a.factration)) AS JAN,

         SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '02', a.factration)) AS FRI,

         SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '03', a.factration)) AS MAR,

         SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '04', a.factration)) AS APR,

         SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '05', a.factration)) AS MAY,

         SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '06', a.factration)) AS JUE,

         SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '07', a.factration)) AS JUL,

         SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '08', a.factration)) AS AGU,

         SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '09', a.factration)) AS SEP,

         SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '10', a.factration)) AS OCT,

         SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '11', a.factration)) AS NOV,

         SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '12', a.factration)) AS DEC

        FROM (SELECT a.userper, a.tel, a.standfee, b.telfeedate, b.factration

         FROM TELFEESTAND a, TELFEE b

         WHERE a.tel = b.telfax) a

        GROUP BY a.userper, a.tel, a.standfee, TO_CHAR(a.telfeedate, 'yyyy')

        說(shuō)明:四表聯(lián)查問(wèn)題:  

        SQL: 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 .....

        說(shuō)明:得到表中最小的未使用的ID號(hào)

        SQL: 

        SELECT (CASE WHEN EXISTS(SELECT * FROM Handle b WHERE b.HandleID = 1) THEN MIN(HandleID) + 1 ELSE 1 END) as HandleID

         FROM Handle

         WHERE NOT HandleID IN (SELECT a.HandleID - 1 FROM Handle a)

       

       

        相關(guān)評(píng)論

        閱讀本文后您有什么感想? 已有人給出評(píng)價(jià)!

        • 8 喜歡喜歡
        • 3 頂
        • 1 難過(guò)難過(guò)
        • 5 囧
        • 3 圍觀圍觀
        • 2 無(wú)聊無(wú)聊

        熱門(mén)評(píng)論

        最新評(píng)論

        發(fā)表評(píng)論 查看所有評(píng)論(0)

        昵稱:
        表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
        字?jǐn)?shù): 0/500 (您的評(píng)論需要經(jīng)過(guò)審核才能顯示)