MySQL數據庫-03(字段的約束)

字段的約束

  • (一)常用約束介紹
  • (二)創建帶約束字段的語法格式
  • (三)主鍵與自增長
  • (四)非空
  • (五)唯一
  • (六)默認值


(一)常用約束介紹

  • 主鍵(primary key):值不能重復,auto_increment 代表值自動增長;
  • 非空(not null):此字段不允許填寫空值;
  • 唯一(unique):此字段不允許重復;
  • 默認值(default):當不填寫此值時會使用默認值,如果填寫時以填寫為準。

(二)創建帶約束字段的語法格式

create table 表名(字段名 數據類型 約束,字段名 數據類型 約束...
);

(三)主鍵與自增長

  • 帶有 primary key(主鍵)的字段,值不能重復;
  • auto_increment 為自增長;
create table 表名(字段名 數據類型 primary key auto_increment,字段名 數據類型 約束...
);

例1:創建表 d,字段要求如下:
id:數據類型為 int unsigned(無符號整數),primary key(主鍵),auto_increment(自增長);
name:數據類型為varchar(字符串),長度為10;
age:數據類型為 int(整數)。

create table d(id int unsigned primary key,name varchar(10),age int
);

(這個要先把第七行“運行已選擇的”,再把第八行“運行已選擇的”)
在這里插入圖片描述
主鍵:不能重復。這里是 id 不能重復。
如果插入一條相同 id 的記錄(id 為1),會是什么結果呢?
在這里插入圖片描述
報錯啦。

我們來查詢一下表 d :
在這里插入圖片描述
name還是’貂蟬’,name值為’妲己’的記錄并沒有插入。

▲我們來看“auto_increment”的作用:
首先,我們drop刪除一下表:

drop table d;

然后,新建表d:

CREATE TABLE d(id INT UNSIGNED PRIMARY key aotu_increment,name VARCHAR(10),age int
);

我們只插入了指定字段,沒有插入 id,它會自動把 id 寫成 1。

在這里插入圖片描述
插入第二條沒有指定 id 的記錄的時候,id自動寫成2。
在這里插入圖片描述

如果插入一條指定 id 的記錄,查詢結果的 id 是指定的 id 值。
在這里插入圖片描述
▲ 如果插入數據時,插入所有字段,但又沒寫自增長字段的值,insert 語句會出錯。

insert into d values ('甄姬',20);

解決方案:
使用占位符,通常使用0 或者null 來占位。

insert into d (id,name,age) values (0,'甄姬',20);
insert into d (id,name,age) values (null,'甄姬',20);

▲ truncate 和 delete:
delete:刪除后再次新建,id 會接著原來的最后一條記錄的 id 值繼續自增,不會回到1。
truncate:刪除后再次新建,id 從1開始。


(四)非空

帶有 not null (非空)的字段,值不能為空。

create table 表名(字段名 數據類型 not null,...
);

例1:創建表 e,字段要求如下:
id:數據類型為 int unsigned(無符號整數);
name:數據類型為 varchar,長度為10,not null;
age:數據類型為 int。

create table e(id int unsigned,name varchar(10) not null,age int
);

▲ 非空字段表,insert 插入數據一定要指定字段值,不然會插入失敗。


(五)唯一

此字段的值不允許重復。

create table 表名(字段名 數據類型 unique,...
);

例1:
創建表 f,字段要求如下:
id:數據類型為 int;
name:數據類型為 varchar,長度為10,unique;
age:數據類型為 int。

create table f(id int,name varchar(10) unique,age int
);

▲ 唯一字段的表,insert 語句插入數據。
例2:表 f 插入一條記錄

insert into f values (1,'瑤',18);

例3:如果插入的記錄中 name 值重復,會插入失敗。

insert into f values (2,'瑤',20);

(六)默認值

當不填寫此值時會使用默認值,如果填寫時以填寫為準。

create table 表名(字段名 數據類型 default,...
);

例1:
創建表 g,字段要求如下:
id:數據類型為 int;
name:數據類型為 varchar,長度為10;
age:數據類型為 int,default,30。

create table g(id int,name varchar(10),age int default 30
);

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/98847.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/98847.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/98847.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【數據可視化-112】使用PyEcharts繪制TreeMap(矩形樹圖)完全指南及電商銷售數據TreeMap繪制實戰

🧑 博主簡介:曾任某智慧城市類企業算法總監,目前在美國市場的物流公司從事高級算法工程師一職,深耕人工智能領域,精通python數據挖掘、可視化、機器學習等,發表過AI相關的專利并多次在AI類比賽中獲獎。CSDN…

Linux下編譯MMCV

介紹 MMCV 有兩個主要版本,mmcv 和 mmcv-lite。 mmcv 是全面版本,包含所有的特性以及豐富的開箱即用的 CUDA 算子,但構建時間較長;mmcvlite 是精簡版,不包含 CUDA 算子,但擁有其他所有功能,適…

Spring Boot 分布式事務常見問題:Seata、XA 與本地消息表對比

一、前言在單體應用中,事務一般由關系型數據庫本身來保證,通過 ACID 特性實現數據一致性。但隨著微服務架構的普及,應用被拆分為多個獨立服務,數據可能分散在不同數據庫、不同存儲引擎中,傳統的單機事務無法再覆蓋。這…

Transporter App 使用全流程詳解:iOS 應用 ipa 上傳工具、 uni-app 應用發布指南

在 iOS 應用開發與發布過程中,Transporter App 是蘋果官方提供的一款上傳工具,專門用于將 ipa 文件 或 應用資源 上傳到 App Store Connect。 與 Xcode 上傳 相比,Transporter 更加穩定,尤其適合大文件上傳,因此在 iOS…

計算機畢業設計 基于Hadoop的B站數據分析可視化系統的設計與實現 Python 大數據畢業設計 Hadoop畢業設計選題【附源碼+文檔報告+安裝調試】

博主介紹:?從事軟件開發10年之余,專注于Java技術領域、Python、大數據、人工智能及數據挖掘、小程序項目開發和Android項目開發等。CSDN、掘金、華為云、InfoQ、阿里云等平臺優質作者? 🍅文末獲取源碼聯系🍅 👇&…

使用自定義LLM和Embedding模型部署Vanna:基于RAG的Text-to-SQL生成

使用自定義LLM和Embedding模型部署Vanna:基于RAG的Text-to-SQL生成 說明: 首次發表日期:2024-07-12Vanna Github地址: https://github.com/vanna-ai/vannaVanna官方文檔: https://vanna.ai/ 部署Vanna時我們可以選擇使…

Linux多線程概念

背景知識內存管理OS進行內存管理不是以字節為單位的,而是以內存塊為單位的,默認大小為4kb;系統和磁盤文件進行IO交互的單位是4kb(8個扇區);OS對內存管理實質上是對頁框進行管理。頁框(Page Fram…

【Problem】動態規劃之跳躍游戲系列

一、跳躍游戲 55. 跳躍游戲 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/jump-game/description/?envTypeproblem-list-v2&envIddynamic-programming class Solution { public:bool canJump(vector<int>& nums) {// 狀態定義&#x…

射頻EVM

EVM&#xff08;Error Vector Magnitude&#xff0c;誤差矢量幅度&#xff09;是衡量無線通信系統中調制質量的重要指標&#xff0c;尤其用于評估信號的調制誤差和系統性能。它通常用來表示傳輸信號與理想信號之間的偏差&#xff0c;特別是在數字通信中。EVM的基本概念&#xf…

Java 更改 Word 文檔中文本顏色

在日常的自動化文檔處理中&#xff0c;我們經常會遇到需要對 Word 文檔內容進行編程修改的需求&#xff0c;其中一項常見且重要的操作就是更改文本的顏色。無論是為了突出重點、統一品牌風格&#xff0c;還是實現動態內容展示&#xff0c;精準地修改文本顏色都是一個核心痛點。…

STM32—SPI協議

文章目錄一、SPI 協議簡介二、硬件電路2.1.SPI的連接2.2.數據的移位2.3.時序基本單元2.3.1.起始條件和終止條件2.3.2.模式 02.3.3.模式 12.3.4.模式 22.3.5.模式 32.4.時序三、軟件實現四、W25Q644.1.簡介4.2.硬件電路4.3.框圖4.4.操作注意事項五、實驗一、SPI 協議簡介 SPI&a…

Qt中的QWebEngineView

第1章 本地目錄結構1.1 自己寫的兩個網頁(html)mermaid.html &#xff08;自己寫的網頁界面&#xff09;WebTest.html (自己寫的網頁界面)qwebchannel.js (Qt下載安裝之后&#xff0c;會在安裝目錄下有這個文件&#xff0c;需要將安裝目錄下的改文件拷貝…

Flutter 應用國際化 (i18n) 與本地化 (l10n) 完整指南

Flutter 國際化 (i18n) 完全指南&#xff1a;從入門到精通 在現代移動應用開發中&#xff0c;支持多語言是觸達全球用戶的基本要求。Flutter 提供了強大且靈活的國際化 (i18n) 和本地化 (l10n) 支持。本文將帶你從零開始&#xff0c;一步步深入掌握在 Flutter 中實現國際化的幾…

計算機視覺與深度學習 | 計算機視覺中線特征提取與匹配算法綜述

文章目錄 一、線特征提取算法原理 1.1 Hough變換及其優化 1.2 LSD算法 1.3 EDLines算法 二、核心數學公式 2.1 直線表示與誤差計算 2.2 LSD算法關鍵公式 三、線特征匹配算法 3.1 LBD描述符 3.2 匹配策略 四、代碼實現 4.1 LSD線段檢測(Python) 4.2 LBD特征匹配(C++) 五、算…

Transformer 模型:Attention is All You Need 的真正含義

2017 年&#xff0c;Google Brain 發布了一篇具有里程碑意義的論文——《Attention Is All You Need》&#xff0c;這篇論文不僅首次提出了 Transformer 模型&#xff0c;更重要的是&#xff0c;它宣稱“注意機制&#xff08;Attention Mechanism&#xff09;就足以構建強大的模…

數據庫約束表的設計

數據庫約束概念&#xff1a;數據庫約束是關系型數據庫的一個重要功能&#xff0c;主要是保證數據的完整性&#xff0c;也可理解為數據的正確性&#xff08;數據本身是否正確&#xff0c;關聯關系是否正確&#xff09;&#xff08;一般是用在指定列上&#xff09;常見的約束類型…

【案例分享】TeeChart 助力 Softdrill 提升油氣鉆井數據可視化能力

在鉆井與地質工程領域&#xff0c;數據可視化是核心環節。圖表不僅需要精確與高效&#xff0c;還需符合行業習慣并支持交互與定制。Softdrill 自 2012 年起在核心產品中集成了TeeChart 圖表庫&#xff0c;將復雜的井下數據轉化為直觀的工程圖表&#xff0c;極大提升了鉆井工程師…

【Flink】Flink Runtime 架構設計

Flink Runtime 架構設計 整體架構 ┌─────────────────────────────────────────────────────────────────┐ │ Flink Runtime │ ├─────────…

Git 命令教程

Git介紹 分布式版本控制系統。 Git命令 初始化/全局配置git init初始化一個Git倉庫&#xff08;會創建一個.git的目錄&#xff09;git config --global user.name “name”設置提交時的用戶名git config user.name查看設置的用戶名git config --global user.email “youemail.c…

git config --global user.name指令報錯時的解決方案

問題分析 %HOMEDRIVE%%HOMEPATH%/.gitconfig 是Windows環境變量的表示方式&#xff1a; %HOMEDRIVE% 通常是 C:%HOMEPATH% 通常是 \Users\你的用戶名完整路徑應該是&#xff1a;C:\Users\你的用戶名\.gitconfig 但這里環境變量沒有被正確解析&#xff0c;顯示的是字面意思。 …