真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

MySQL中DDL數(shù)據(jù)定義語句有哪些

小編給大家分享一下MySQL中DDL數(shù)據(jù)定義語句有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

成都創(chuàng)新互聯(lián)公司主要從事成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)金水,10多年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):13518219792

一、DDL數(shù)據(jù)定義語句

庫的管理

創(chuàng)建:create database [if not exists] 庫名;
修改:若需要修改庫名,直接修改文件夾
刪除:DROP DATABASE IF EXISTS 庫名;

表的管理

創(chuàng)建

create table IF NOT EXISTS 表名(
列名 列的類型[長度、約束],
列名 列的類型[長度、約束],
列名 列的類型[長度、約束],
...
)

修改
alter table 表名 add|drop|modify|change column 列名 [列類型 約束];

刪除
drop table 表名;

【庫的管理】# 創(chuàng)建庫CREATE DATABASE IF NOT EXISTS books;# 修改庫的字符集ALTER DATABASE books CHARACTER SET gbk;# 刪除庫DROP DATABASE IF EXISTS books;【表的管理】# 1.創(chuàng)建表CREATE TABLE IF NOT EXISTS book(
	id INT,
	bName VARCHAR(20),
	authorID INT,
	publishDate DATETIME);DESC book;CREATE TABLE author(
	id INT,
	au_name VARCHAR(20),
	nation VARCHAR(10));DESC author;# 2.修改表# 修改列名ALTER TABLE book CHANGE COLUMN publishDate pubDate DATETIME;# 修改列的類型或約束ALTER TABLE book MODIFY COLUMN pubdate TIMESTAMP;# 添加新列ALTER TABLE author ADD COLUMN annual DOUBLE; # 添加新列作為第一個字段ALTER TABLE author ADD COLUMN newT1 INT FIRST;# 添加新列在指定的列后ALTER TABLE author ADD COLUMN newT2 INT AFTER newT1;# 刪除列ALTER TABLE author DROP COLUMN annual;# 修改表名ALTER TABLE author RENAME TO book_author;# 3.表的刪除DROP TABLE IF EXISTS book_author;SHOW TABLES;# 4.表的復(fù)制INSERT INTO author VALUES(1,'小櫻','日本'),(2,'悟空','中國'),(3,'綠巨人','美國'),(4,'哪吒','中國');# 僅復(fù)制表的結(jié)構(gòu)CREATE TABLE author2 LIKE author;# 復(fù)制表的結(jié)構(gòu)+數(shù)據(jù)CREATE TABLE author3 SELECT * FROM author;# 只復(fù)制部分數(shù)據(jù)CREATE TABLE author4 SELECT id,au_name FROM author WHERE nation='中國';# 僅復(fù)制某些字段CREATE TABLE author5 SELECT id,au_name FROM author WHERE 1=2;

二、數(shù)據(jù)類型

2.1 整型

整數(shù)類型別名字節(jié)無符號范圍有符號范圍
Tinint微整型10~255-128~127
Smallin小整型20~65535-32768~32767
Mediumint中整型30~1677215-8388608~8388607
Int或Integer整型40~4294967295-2147483648~2147483647
Bigint大整型80~9223372036854775807*2+1-9223372036854775808~9223372036854775807
【整型】# 1.默認為有符號,可以添加unsigned設(shè)置為無符號CREATE TABLE IF NOT EXISTS tab_int(
	t1 INT, # 有符號
	t2 INT UNSIGNED, # 無符號
	t3 INT ZEROFILL #添加zerofill后自動變更為無符號整型,位數(shù)不夠0填充.);DESC tab_int;SELECT * FROM tab_int;# 2.如果插入的數(shù)值超出了整型的范圍,會報out of range異常INSERT INTO tab_int VALUES(2147483648,1);# 3.如果不設(shè)置長度,會有默認的長度,位數(shù)不夠時0填充(前提是字段有ZEROFILL).

2.2 小數(shù)

浮點數(shù)類型字節(jié)范圍
float(M,D)4-2^128 ~ +2^128
double(M,D)8-2^1024 ~ +2^1024
定點數(shù)類型\\
DEC(M,D)M+2最大取值范圍與double相同,給定decimal的有效范圍由M和D決定

注意:
M:整數(shù)部位+小數(shù)部位的總長度
D:小數(shù)部位
D和M都省略時:
1、如果是decimal類型,則M默認為10,D默認為0;
2、如果是floact和double,會根據(jù)插入的數(shù)值的精確度來決定精度。
3、定點型的精確度較高,如果要求插入數(shù)值的精確度較高如貨幣運算則考慮使用。

2.3 字符型

字符串類型M是否可以省略特點空間耗費效率范圍
char(M)M可以省略,默認為1定長比較耗費M為0~255之間的整數(shù)
varchar(M)M不可以省略可變長比較節(jié)省M為0~65535之間的整數(shù)

binaryvarbinary類型,類似于char和varchar,不同的是它們包含二進制字符而不包含非二進制字符,即保存較短的二進制。

Bit(M)類型,字節(jié)為1~8,范圍為Bit(1)~Bit(8)。

Enum類型,即枚舉類型,要求插入的值必須屬于列表中指定的值之一,如果列成員為1~255,則需要1個字節(jié)存儲;如果列成員為255~65535,則需要2個字節(jié)存儲,最多需要65535個成員。

Set類型,和Enum類似,可以保存0~64個成員。和Enum最大的區(qū)別是:Set類型一次可以選取多個成員,而Enum只能選一個,根據(jù)成員個數(shù)不同,存儲所占的字節(jié)也不同。

成員數(shù)字節(jié)數(shù)
1~81
9~162
17~243
25~324
33~648
【枚舉】CREATE TABLE tab_set(
	s1 SET('a','b','c'));INSERT INTO tab_set VALUES('a');INSERT INTO tab_set VALUES('c,a');INSERT INTO tab_set VALUES('a,b,c');# 插入后,內(nèi)部會進行排序,如插入c,a會變成a,c

2.4 日期類型

日期和時間類型特點字節(jié)最小值最大值
date只保存日期41000-01-019999-12-31
datetime保存日期+時間81000-01-01 00:00:009999-12-31 23:59:59
timestamp(使用較多)保存日期+時間41870010800012038年的某個時刻
time只保存時間3-838:59:59838:59:59
year只保存年119012155

timestamp和實際時區(qū)有關(guān),更能反映實際的日期;datetime則只能反映出插入時的當?shù)貢r區(qū)。
timestamp的屬性受Mysql版本和SQLMode的影響很大。

【日期類型】CREATE TABLE tab_date(
	t1 DATETIME, # 不受時區(qū)影響
	t2 TIMESTAMP # 受時區(qū)影響);INSERT INTO tab_date VALUES(NOW(),NOW());SET time_zon='+8:00';# 設(shè)置時區(qū)SHOW VARIABLES LIKE 'time_zone'; #顯示當前時區(qū)

二、六大約束

含義:一種限制,用于限制表中的數(shù)據(jù),為了保證表中數(shù)據(jù)的準確性和可靠性。

NOT NULL非空約束,規(guī)定某個字段不能為空
UNIQUE唯一約束,規(guī)定某個字段在整個表匯中是唯一的
PRIMARY KEY主鍵(唯一且非空)
FOREIGN KEY外鍵
CHECK檢查約束(mysql中不支持)
DEFAULT默認值,保證該字段有默認值

列級約束:六大約束語法上都支持,但外鍵約束沒有效果。

表級約束:除了非空、默認,其他都支持。

常用的做法是:其他約束都寫在列級,外鍵約束寫在表級。

主鍵和唯一對比是否保證唯一性是否允許為空允許有幾個是否允許組合(不推薦)
主鍵×至多一個主鍵允許組合主鍵
唯一√(允許有一個null)可以有多個唯一允許組合唯一

外鍵的特點:

  • 要求在從表設(shè)置外鍵關(guān)系。

  • 從表的外鍵列的類型和主表的關(guān)聯(lián)列的類型要求一致或兼容,名稱無要求。

  • 主表的關(guān)聯(lián)列必須是一個key(一般是主鍵或唯一)

  • 插入數(shù)據(jù)時,先插入主表再插入從表;刪除數(shù)據(jù)時,先刪除從表再刪除主表。

列級約束和表級約束比較位置支持的約束類型是否可以起別名
列級約束列的后面語法都支持,但外鍵沒有效果不可以
表級約束所有列的下面默認和非空不支持,其他支持可以(主鍵沒有效果)
【列級約束】
直接在字段名和類型后面追加約束類型。
注意:只支持默認、非空、主鍵、唯一,不支持外鍵約束CREATE DATABASE students;USE students;CREATE TABLE major(
	id INT PRIMARY KEY,# 主鍵
	majorName VARCHAR(20));CREATE TABLE stuinfo(
	id INT PRIMARY KEY,# 主鍵
	stuName VARCHAR(20) NOT NULL, #非空
	gender CHAR(1) CHECK(gender='男' OR gender='女'),#檢查
	seat INT UNIQUE,# 唯一
	age INT DEFAULT 18, #默認約束
	majorId INT REFERENCES major(id) # 外鍵);DESC stuinfo;SHOW INDEX FROM stuinfo; # 查看表中所有的索引,外鍵,唯一【表級約束】# 語法:[CONSTRAINT 約束名 ] 約束類型(字段名)DROP TABLE IF EXISTS stuinfo;CREATE TABLE stuinfo(
	id INT,
	stuname VARCHAR(20),
	gender CHAR(1),
	seat INT,
	age INT,
	majorid INT,
	CONSTRAINT pk PRIMARY KEY(id),# 主鍵
	CONSTRAINT uq UNIQUE(seat), # 唯一
	CONSTRAINT ck CHECK(gender='男' OR gender='女'),# 檢查(不報錯,但無效)
	CONSTRAINT fk_stuinfo_major FOREIGN KEY(majorid) REFERENCES major(id) # 外鍵);SHOW INDEX FROM stuinfo;【修改表時添加約束】# 添加非空約束ALTER TABLE stuinfo MODIFY COLUMN stuname VARCHAR(20) NOT NULL;# 添加默認約束ALTER TABLE stuinfo MODIFY COLUMN age INT DEFAULT 18;# 添加主鍵ALTER TABLE stuinfo MODIFY COLUMN id INT PRIMARY KEY;# 添加唯一鍵ALTER TABLE stuinfo MODIFY COLUMN seat INT UNIQUE;# 添加外鍵ALTER TABLE stuinfo ADD CONSTRAINT fk_stuinfo_major FOREIGN KEY(majorid) REFERENCES major(id);DESC stuinfo;SHOW INDEX FROM stuinfo;【修改表時刪除約束】# 刪除非空約束ALTER TABLE stuinfo MODIFY COLUMN stuname VARCHAR(20) NULL;# 刪除默認約束ALTER TABLE stuinfo MODIFY COLUMN age INT;# 刪除主鍵ALTER TABLE stuinfo DROP PRIMARY KEY;# 刪除唯一ALTER TABLE stuinfo DROP INDEX seat;# 刪除外鍵ALTER TABLE stuinfo DROP FOREIGN KEY fk_stuinfo_major;

學習了約束,嘗試完成秈米的測試題MySQL中DDL數(shù)據(jù)定義語句有哪些
1、列級約束:
ALTER TABLE emp2 MODIFY COLUMN id INT PRIMARY KEY;# 列約束不支持起名字
表級約束:
ALTER TABLE emp2 ADD CONSTRAINT my_emp_id_pk PRIMARY KEY(id);# 實際上主鍵起了名字也沒效果
2、與1類似
3、
ALTER TABLE emp2 ADD COLUMN dept_id INT;
ALTER TABLE emp2 ADD CONSTRAINT fk_emp2_dept2 FOREIGN KEY(dept_id) REFERENCES dept2(id);

四、標識列

標識列又稱為自增長列,其實也可以將標識列納入約束的范圍。

含義:可以不用手動的插入值,系統(tǒng)提供默認的序列值。

特點:
1.標識列不一定非要和主鍵搭配,但要求是一個key。
2.一個表至多可以有一個表示列。
3.表示列的類型只能為數(shù)值型。
4.標識列可以通過SET auto_increment_increment=3;設(shè)置步長,也可以通過手動插入值來設(shè)置起始值。

【創(chuàng)建表時設(shè)置標識列】DROP TABLE IF EXISTS tab_identity;CREATE TABLE tab_identity(
	id INT PRIMARY KEY AUTO_INCREMENT, #設(shè)置自動自增
	NAME VARCHAR(20));INSERT INTO tab_identity VALUE(NULL,'花花');INSERT INTO tab_identity(NAME) VALUE('Hudie');SELECT * FROM tab_identity;SHOW VARIABLES LIKE '%auto_increment%';SET auto_increment_increment=3;#設(shè)置步長為3# 起始值可以通過改變第一條記錄的值來更改TRUNCATE TABLE tab_identity;【修改表時設(shè)置標識列】CREATE TABLE tab_identity(
	id INT, #設(shè)置自動自增
	NAME VARCHAR(20));# 設(shè)置主鍵和標識列ALTER TABLE tab_identity MODIFY COLUMN id INT PRIMARY KEY AUTO_INCREMENT;修改表時刪除標識列【】ALTER TABLE tab_identity MODIFY COLUMN id INT;

五、級聯(lián)刪除與置空

級聯(lián)刪除:
ALTER TABLE stuinfo ADD CONSTRAINT fk_stu_major FOREIGN KEY(majorid) REFERENCES major(id) ON DELETE CASCADE;
級聯(lián)置空:
ALTER TABLE stuinfo ADD CONSTRAINT fk_stu_major FOREIGN KEY(majorid) REFERENCES major(id) ON DELETE SET NULL;

【演示級聯(lián)刪除、級聯(lián)置空】DROP TABLE major,stuinfoCREATE TABLE IF NOT EXISTS major(
	id INT PRIMARY KEY,
	majorName VARCHAR(20));INSERT INTO majorVALUES(1,'Java'),(2,'Python'),(3,'Go');CREATE TABLE IF NOT EXISTS stuinfo(
	id INT,
	stuname VARCHAR(20),
	gender CHAR(1),
	seat INT,
	age INT,
	majorid INT);INSERT INTO stuinfoSELECT 1,'join1','女',NULL,NULL,1 UNION ALLSELECT 2,'join2','女',NULL,NULL,1 UNION ALLSELECT 3,'join3','女',NULL,NULL,2 UNION ALLSELECT 4,'join4','女',NULL,NULL,2 UNION ALLSELECT 5,'join5','女',NULL,NULL,1 UNION ALLSELECT 6,'join6','女',NULL,NULL,3 UNION ALLSELECT 7,'join7','女',NULL,NULL,3 UNION ALLSELECT 8,'join8','女',NULL,NULL,1);SELECT * FROM major;SELECT * FROM stuinfo;# 傳統(tǒng)方式添加外鍵ALTER TABLE stuinfo ADD CONSTRAINT fk_stu_major FOREIGN KEY(majorid) REFERENCES major(id);# 刪除major表的3號專業(yè)# 方式1:級聯(lián)刪除#   先刪除外鍵ALTER TABLE stuinfo DROP FOREIGN KEY fk_stu_major;#   添加外鍵時添加級聯(lián)刪除ALTER TABLE stuinfo ADD CONSTRAINT fk_stu_major FOREIGN KEY(majorid) REFERENCES major(id) ON DELETE CASCADE;DELETE FROM major WHERE id =3;# 方式2:級聯(lián)置空#   先刪除外鍵ALTER TABLE stuinfo DROP FOREIGN KEY fk_stu_major;#   添加外鍵時添加級聯(lián)置空ALTER TABLE stuinfo ADD CONSTRAINT fk_stu_major FOREIGN KEY(majorid) REFERENCES major(id) ON DELETE SET NULL;DELETE FROM major WHERE id =2;

以上是“MySQL中DDL數(shù)據(jù)定義語句有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


網(wǎng)頁標題:MySQL中DDL數(shù)據(jù)定義語句有哪些
文章地址:http://weahome.cn/article/iphhjs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部