国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

讀SQL進階教程筆記14_SQL編程要點

這篇具有很好參考價值的文章主要介紹了讀SQL進階教程筆記14_SQL編程要點。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

讀SQL進階教程筆記14_SQL編程要點

1.?消滅NULL

1.1.?NULL惹人討厭的原因

1.1.1.?進行SQL編碼時,必須考慮違反人類直覺的三值邏輯

1.1.2.?指定IS NULL、IS NOT NULL的時候,不會用到索引,SQL語句執(zhí)行起來性能低下

1.1.2.1.

   1 + NULL = NULL
   2- NULL = NULL
    3 * NULL = NULL
    4 / NULL = NULL
    NULL / 0 = NULL

1.1.3.?四則運算以及SQL函數(shù)的參數(shù)中包含NULL,會引起“NULL的傳播”

1.1.4.?接收SQL查詢結(jié)果的宿主語言中,NULL的處理方法沒有統(tǒng)一標準

1.1.4.1.?Oracle不區(qū)分空字符串和NULL

1.1.4.2.?Visual Basic是區(qū)分的

1.1.5.?與一般列的值不同,NULL是通過在數(shù)據(jù)行的某處加上多余的位(bit)來實現(xiàn)的,使程序占據(jù)更多的存儲空間,使得檢索性能變差

1.2.?無法完全消除NULL

1.2.1.?僅僅靠在表中所有列加上NOT NULL的約束是不夠的

1.2.2.?在使用外連接,或者SQL-99中添加的帶CUBE或ROLLUP的GROUP BY時,還是很容易引入NULL的

1.3.?消除NULL的具體做法

1.3.1.?首先分析能不能設置默認值

1.3.2.?僅在無論如何都無法設置默認值時允許使用NULL

1.3.3.?編號:使用異常編號

1.3.3.1.?ISO的性別編號

1.3.3.1.1.?“1:男性”“2:女性”

1.3.3.1.2.?“0:未知”“9:不適用”

1.3.3.1.2.1.?編號9可用于法人的情況

1.3.3.1.2.2.?由Codd區(qū)分的兩類NULL“未知”和“不適用”相吻合了

1.3.3.2.?插入編號未知的顧客信息時,定義一個表示未知的編號“×××××”就可以了

1.3.3.2.1.?避免使用“99999”這樣的編號作為異常編號

1.3.3.2.2.?可能會出現(xiàn)用來表示異常的編號和真實的顧客編號重復的情況

1.3.3.3.?編號列應該使用字符串類型

1.3.4.?名字:使用“無名氏”

1.3.4.1.?賦予表示未知的值

1.3.4.1.1.?UNKNOWN

1.3.5.?數(shù)值:用0代替

1.3.5.1.?對于數(shù)值型的列,將NULL轉(zhuǎn)換為0再存儲到數(shù)據(jù)庫中

1.3.5.2.?如果允許NULL,那么就必須在統(tǒng)計數(shù)據(jù)時使用NULLIF函數(shù)或者IS NOT NULL謂詞來排除NULL

1.3.5.3.?如果一定要區(qū)分0和NULL,那么允許使用NULL

1.3.5.4.?“沒有油箱的車”和“空油箱”是不同的

1.3.6.?日期:用最大值或最小值代替

1.3.6.1.?開始日期和結(jié)束日期這樣的“期限”的時候,我們可以使用0000-01-01或者9999-12-31這樣可能存在的最大值或最小值來處理

1.3.6.2.?當NULL的含義是“未知”的時候,可以允許使用NULL

1.3.6.2.1.?當默認值原本就不清楚的時候,例如歷史事件發(fā)生的日期,或者某人的生日等

2.?名字和意義

2.1.?如果沒有為索引和約束顯式地指定名稱,DBMS就會自動為之分配隨機的名稱,這也是應該避免的

2.2.?為內(nèi)聯(lián)視圖命名

2.3.?命名時允許的字符有以下3種

2.3.1.?英文字母

2.3.2.?阿拉伯數(shù)字

2.3.3.?下劃線“_”

2.4.?標準SQL中規(guī)定名稱的第一個字符應該是英文字母

3.?屬性和列

3.1.?列代表的是“屬性”,應該具有一貫性

3.2.?“根據(jù)位置調(diào)用數(shù)據(jù)”是明確禁止的

3.2.1.?對于存儲了“年份不同格式就不同的報表”這類值的表,格式切換的時間點不同,某一列中存儲的值的意義就會發(fā)生變化

3.2.2.?使用某一列去管理多種編號(都道府縣編號或客戶編號等)

4.?注釋

4.1.?“--”單行注釋的寫法

4.2.?“/* */”去寫多行注釋

5.?縮進

5.1.?代碼難以閱讀的原因

5.1.1.?沒有進行縮進

5.1.2.?沒有對長代碼劃分模塊,所有的都揉在一起

5.2.?所有關(guān)鍵字都頂格左齊的寫法比讓關(guān)鍵字右齊的寫法更好

5.2.1.?緊接著的列名或表名的位置也能對齊,代碼更易讀

6.?大小寫

6.1.?不成文的約定

6.1.1.?關(guān)鍵字使用大寫字母,列名和表名使用小寫字母

7.?空格

7.1.?不管用什么語言編程都一樣,代碼中需要適當?shù)亓粢恍┛崭?/h3>

8.?逗號

8.1.?前置逗號

8.1.1.

 SELECT     col_1

            ,  col_2
            ,  col_3
            ,  col_4
      FROM  tbl_A;

8.1.1.1.?刪掉最后一列“col_4”后執(zhí)行也不會出錯

8.1.1.2.?每行中逗號都出現(xiàn)在同一列,因此使用Emacs等可以進行矩形區(qū)域選擇的編輯器就會非常方便操作

8.1.2.?把逗號寫在要素和要素的中間

8.1.3.?SQL格式化/美化

8.1.3.1.?dbeaver不支持

8.1.3.2.?navicat不支持

8.1.3.3.?sql prompt 支持

9.?不使用通配符

9.1.?因為結(jié)果的格式依賴于列的排列順序,所以修改表中列的排列順序,或者添加、修改列就會導致結(jié)果的格式發(fā)生變化

10.?ORDER BY中不使用列編號

10.1.?這個功能在SQL-92中已經(jīng)被列為了“未來會被刪除的功能”

10.2.?一般來說會受列的順序和位置影響的寫法都應該避免,這也是一條鐵律

11.?SQL標準語法

11.1.?不使用依賴各種數(shù)據(jù)庫實現(xiàn)的函數(shù)和運算符

11.1.1.?DECODE(Oracle)、IF(MySQL)、NVL(Oracle)、STUFF(SQL Server)等

11.1.2.?使用CASE表達式或者COALESCE、NULLIF等標準函數(shù)代替

11.2.?SIGN或ABS、REPLACE這些,雖然標準SQL沒有定義它們,但是幾乎所有的數(shù)據(jù)庫都實現(xiàn)了

11.3.?標準SQL中有定義,但是各數(shù)據(jù)庫實現(xiàn)情況不同的功能

11.3.1.?日期函數(shù)EXTRACT,以及用于字符串連接的運算符“||”或者POSITION函數(shù)

12.?連接操作

12.1.?使用INNER或CROSS等表明連接類型的關(guān)鍵字,連接條件可以使用ON子句分開寫

12.1.1.?一眼就能看明白連接的類型和條件,代碼可讀性很好

12.2.?外連接請使用LEFT OUTER JOIN、RIGHT OUTER JOIN或者FULL OUTER JOIN來寫

12.3.?標準SQL中允許省略關(guān)鍵字OUTER,但是這個關(guān)鍵字便于我們理解它是外連接而非內(nèi)連接,所以還是寫上吧

12.4.?左連接有一個優(yōu)勢:一般情況下表頭都出現(xiàn)在左邊

13.?從FROM子句開始寫

13.1.?SQL中各部分的執(zhí)行順序是:FROM→WHERE→GROUP BY→HAVING→SELECT(→ORDER BY)

13.2.?嚴格地說,ORDER BY并不是SQL語句的一部分,因此可以排除在外

?文章來源地址http://www.zghlxwxcb.cn/news/detail-431645.html

到了這里,關(guān)于讀SQL進階教程筆記14_SQL編程要點的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權(quán),不承擔相關(guān)法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領支付寶紅包贊助服務器費用

相關(guān)文章

  • 讀SQL進階教程筆記11_關(guān)系數(shù)據(jù)庫基礎

    讀SQL進階教程筆記11_關(guān)系數(shù)據(jù)庫基礎

    正式的關(guān)系模型術(shù)語 非正式的日常用語 關(guān)系(relation ) 表(table ) 元組(tuple ) 行(row )或記錄(record ) 勢(cardinality ) 行數(shù)(number of rows ) 屬性(attribute ) 列(column )或字段(field ) 度(degree ) 列數(shù)(number of columns ) 定義域(domain ) 列的取值集合(pool of legal values ) 10.5.3.1.?“泛文件主義” 10.5.3.2.?

    2023年04月14日
    瀏覽(56)
  • 讀SQL進階教程筆記12_地址與三值邏輯

    讀SQL進階教程筆記12_地址與三值邏輯

    5.1.4.1.?命題其實不存在于客觀世界,而存在于我們的內(nèi)心

    2023年04月19日
    瀏覽(56)
  • Docker基礎教程 - 14 Docker進階

    請查看 Docker 進階教程 。

    2024年03月17日
    瀏覽(96)
  • 《吐血整理》進階系列教程-拿捏Fiddler抓包教程(14)-Fiddler斷點(breakpoints)實戰(zhàn),篡改或偽造數(shù)據(jù)

    《吐血整理》進階系列教程-拿捏Fiddler抓包教程(14)-Fiddler斷點(breakpoints)實戰(zhàn),篡改或偽造數(shù)據(jù)

    1.簡介 上一篇主要就講解和分享Fiddler斷點的理論和操作,今天宏哥就用具體例子,將上一篇中的理論知識實踐一下。而且在實際測試過程中,有時候需要修改請求或響應數(shù)據(jù),或者直接模擬服務器響應,此時可以使用fiddler進行此類操作??梢允褂脭帱c功能完成。 2.斷點調(diào)試

    2024年01月22日
    瀏覽(19)
  • Lua 進階 · 教程筆記

    Lua 進階 · 教程筆記

    筆記的內(nèi)容出自 Bilibili 上的視頻:Lua教程-進階部分 - 4K超清【不定期更新】 筆記主要用于供筆者個人或讀者回顧知識點,如有紕漏,煩請指出 : ) 國內(nèi)的大佬 云風 翻譯了 Lua 的 Api 參考手冊:傳送門【】 以后讀者在練習或者開發(fā)途中可以在參考手冊里查看 Lua 提供的 Api。

    2024年01月24日
    瀏覽(97)
  • ROS2 Navigation 進階教程學習筆記 第一章

    ROS2 Navigation 進階教程學習筆記 第一章

    Nav2提供了新的拱你和工具,使創(chuàng)建機器人應用程序變得更容易 在本單元中,將學習 1. 通過simple Commander API進行基本Nav2操作 2. 通過followwaypoints使用waypoint follower和task executor插件 3. 禁區(qū)和限速區(qū)簡介 然后您將基于Nav2創(chuàng)建一個基本的自主機器人demo。您將經(jīng)常在一個仿真?zhèn)}庫中

    2024年02月08日
    瀏覽(22)
  • 【操作寶典】IDE神器解密:IntelliJ IDEA詳細教程,Java編程進階指南!

    【操作寶典】IDE神器解密:IntelliJ IDEA詳細教程,Java編程進階指南!

    目錄 ??1. 新建Java項目 ??2. 運行Java程序 ??3. 創(chuàng)建springboot項目 方法一 導入jar包 ?編輯方法二 maven的安裝配置 ??4. 創(chuàng)建Vue項目 ?編輯4.1 配置node.js ?編輯4.2 idea運行 文件--新建--項目 JAVA模型--JDK 注意: 程序放在src里面 xxx.java則創(chuàng)建的類名只能為xxx 示例程序Hello.java 建議使

    2024年02月05日
    瀏覽(20)
  • aardio教程二) 進階語法

    aardio中除了基礎數(shù)據(jù)類型外,其他的復合對象都是table(例如類和名字空間等)。table可以用來存放aardio的任何對象,包括另一個table。 在其他語言中的字典、列表、數(shù)組、集合映射等,在aardio中都使用table來實現(xiàn)。 創(chuàng)建字典 創(chuàng)建數(shù)組 數(shù)組和字典可以混用 使用class定義類

    2024年03月18日
    瀏覽(99)
  • kotlin教程4:函數(shù)進階

    kotlin教程:編程基礎??數(shù)據(jù)結(jié)構(gòu)??面向?qū)ο?kotlin 的函數(shù)定義非常靈活,既可以按照順序傳參,也可以通過參數(shù)名傳參,而且可以設置參數(shù)默認值,這些在基礎教程中已經(jīng)講過了。 此外, kotlin 中用 vararg 修飾的參數(shù),為長度可變的參數(shù)列表 遞歸是一種常用的編程技巧,就像

    2024年02月05日
    瀏覽(92)
  • SpringBoot進階教程(七十七)WebSocket

    SpringBoot進階教程(七十七)WebSocket

    WebSocket是一種在單個TCP連接上進行全雙工通信的協(xié)議。WebSocket使得客戶端和服務器之間的數(shù)據(jù)交換變得更加簡單,允許服務端主動向客戶端推送數(shù)據(jù)。在WebSocket API中,瀏覽器和服務器只需要完成一次握手,兩者之間就直接可以創(chuàng)建持久性的連接,并進行雙向數(shù)據(jù)傳輸。 很多

    2024年02月08日
    瀏覽(296)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領取紅包,優(yōu)惠每天領

二維碼1

領取紅包

二維碼2

領紅包