0009《SQL必知必會》筆記05-表的創建與約束

来源:http://www.cnblogs.com/sonng/archive/2016/04/22/5420742.html
-Advertisement-
Play Games

1、創建表:用CREATE TABLE 語句,要指明:表名(不能與現有表名重覆)、列名、每列的數據類型 2、約束。資料庫中的表不同於Excel,其表中的數據必須嚴格規範合法,約束就是用來管理如何插入或處理資料庫數據的規則。 1.主鍵約束:主鍵列的每一個數據可以唯一標識其所在的行,任意兩行的主鍵值都不 ...


1、創建表:用CREATE TABLE 語句,要指明:表名(不能與現有表名重覆)、列名、每列的數據類型

CREATE TABLE product
(
    prod_id            char(10),
    vend_id            char(10),
    prod_name          char(254),
    prod_price         number(8,2),
    prod_desc          varchar(1000)  
);

2、約束。資料庫中的表不同於Excel,其表中的數據必須嚴格規範合法,約束就是用來管理如何插入或處理資料庫數據的規則。

  1.主鍵約束:主鍵列的每一個數據可以唯一標識其所在的行,任意兩行的主鍵值都不相同;主鍵值不能為空,因此每行都有一個主鍵值;主鍵列不更新不變化,並且不能重用;主鍵可以創建在一個列或多個列上。關鍵字:PRIMARY KEY

  2.外鍵約束:外鍵約束列的數據必須只能是另一個表的主鍵列(也可以是唯一約束列?)中的數據。比如orders表的cust_id必須是customers表的cust_id列裡面的值,不能在orders.cust_id列添加一個在customers.cust_id列裡面沒有的數據。關鍵字:FOREIGN KEY

  3.唯一約束:唯一約束列的每個數據都是唯一的,任意兩行都不相同。與主鍵的區別:一個表只有一個主鍵約束,但可以有多個唯一約束;唯一約束可以是NULL值;唯一約束列可以修改更新重覆使用;不能用來定義外鍵。比如身份證號就可以做唯一約束(當然現實中有兩個完全相同的身份證號碼的意外情況)。關鍵字:UNIQUE

  4.檢查約束:使得檢查約束列的值符合某個條件,比如購買數量>0;性別為“男”或“女”。關鍵字:CHECK(條件)

  5.非空約束:就是NOT NULL,是否允許某一列的值為空,不設置的話,預設是NULL。註意NULL和‘’的區別。

3、在創建表時創建約束:

CREATE TABLE product
(    prod_id        char(10)       NOT NULL PRIMARY KEY,
     vend_id        char(10)       NOT NULL,
     prod_name      char(254)      NOT NULL,
     prod_price     number(8,2)    NOT NULL CHECK(prod_price>0),
     prod_desc      varchar(1000)  NOT NULL,
CONSTRAINT for_vend_id FOREIGN KEY(vend_id) REFERENCES vendors(vend_id)
);

或者:

CREATE TABLE product
(    prod_id        char(10)       NOT NULL,
     vend_id        char(10)       NOT NULL,
     prod_name      char(254)      NOT NULL,
     prod_price     number(8,2)    NOT NULL,
     prod_desc      varchar(1000)  NOT NULL,
PRIMARY KEY(prod_id),
CHECK(prod_price>0),
CONSTRAINT for_vend_id FOREIGN KEY(vend_id) REFERENCES vendors(vend_id)
);

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、前言部分 沒發現蒲公英之前一直採用非常傻B的方式給公司App做內部測試,要麼發個測試包讓公司測試人員用iTUnes 自己安裝 要麼苦逼的一個個在我Xcode上直接安裝測試包,操作起來又麻煩又苦逼,後來偶然發現了蒲公英感覺這貨還真不是一般 好用。直接上傳測試文件到他們平臺上傳成功後直接將測試地址發 ...
  • 1.一個人上臺階可以一次上1個,2個,或者3個,問這個人上32層的臺階,總共有幾種走法? 思路:先建立數學模型,設3步的走 i 次,2步的走 j 次, 1步的走 k 次,上了3*i + 2*j + 1*k = n個臺階.總共走 i + j + k 次, 等於把n個臺階的長度先劃分成 i + j + ...
  • 需求一:我們製作APP的不可能一個界面來實現所有需求的,我們需要多個界面的跳轉。每個界面各自實現對應的需求,代碼實現多控制器之間的跳轉大致分為三類。一類是使用UINavigationController 跳轉 ,一類是使用UITabBarController 實現多個控制器之間的跳轉,還有一類是使用 ...
  • (轉載請註明出處哦)具體的百度地圖許可權和apikey配置以及基礎地圖的配置不敘述,百度地圖定位可以看這個鏈接的http://blog.csdn.net/heweigzf/article/details/51084358,先來看一波搜索需要的基本佈局layout AutoCompleteTextVie ...
  • 如果要在xib和storyboard里為控制項添加圓角和外框寬度,只要這樣做就可以 layer.borderWidth 設置外框寬度屬性 layer.cornerRadius 設置圓角屬性 只要為屬性設置value值就可以了 當然修改完xib里看是看不出來的,要運行才看得到,效果如下 那如果要在xib ...
  • 有時候在項目中,為了保持前後頁面的推進方式跳轉方式一致,會在通過UIview上的控制項跳到另一個Controller上,所以,這時候就需要用到這種方式了,當然,present方法可以實現跳轉但是樣式可能不同,這時候在我的想法可以使用代理或者回調,當你不熟悉時,就用到了這個方法: 1.參考別人的方法: ...
  • 一、網頁打開APP簡介 Android有一個特性,可以通過點擊網頁內的某個鏈接打開APP,或者在其他APP中通過點擊某個鏈接打開另外一個APP(AppLink),一些用戶量比較大的APP,已經通過發佈其AppLink SDK,開發者需要申請相應的資格,配置相關內容才能使用。這些都是通過用戶自定義的U ...
  • 存儲String字元串,使用get,set命令,一個鍵最大存儲512M 存儲Hash哈希,使用HMSET和HGETALL命令,參數:鍵,值 例如:HMSET user:1 username taoshihan password taoshihan HGETALL user:1 存儲List列表,可以 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...