1.數(shù)據(jù)類型
根據(jù)項(xiàng)目的實(shí)際需要使用合適的數(shù)據(jù)類型陈哑,這也是數(shù)據(jù)優(yōu)化的操作
- 整型
類型 | 存儲(chǔ)范圍 | 字節(jié)數(shù) |
---|---|---|
TINYINT | 有符號(hào)值:-128 到 127 (-27 到 27-1) 無符號(hào)值:0 到 255 (0 到 28-1) |
1 |
SMALLINT | 有符號(hào)值:-32768 到 32767 (-215 到 215-1) 無符號(hào)值:0 到 65535 (0 到 216-1) |
2 |
MEDIUMINT | 有符號(hào)值:-8388608 到 8388607 (-223 到 223-1) 無符號(hào)值:0 到 16777215 (0 到 224-1) |
3 |
INT | 有符號(hào)值:-2147483648 到 2147483647 (-231 到 231-1) 無符號(hào)值:0 到 4294967295 (0 到 232-1) |
4 |
BIGINT | 有符號(hào)值:-9223372036854775808 到9223372036854775807 (-263 到 263-1) 無符號(hào)值:0 到 18446744073709551615 (0 到 264-1) |
8 |
- 浮點(diǎn)型
類型 | 存儲(chǔ)范圍 | 字節(jié)數(shù) |
---|---|---|
FLOAT[(M,D)] | -3.402823466E+38 到 -1.175494351E-38塑娇、 0 和 1.175494351E-38 到 3.402823466E+38景用。 M是數(shù)字的總位數(shù)打肝,D是小數(shù)點(diǎn)后面的位數(shù)。如果M和D被省略灸撰,則根據(jù)硬件允許的限制來保存值泻骤。單精度浮點(diǎn)數(shù)精確到大約7位小數(shù)位。 |
4 |
DOUBLE[(M,D)] | -1.7976931348623157E+308 到 -2.2250738585072014E-308梧奢、 0 和 2.2250738585072014E-308 到 1.7976931348623157E+308 | 8 |
- 字符型
類型 | 存儲(chǔ)需求 | 用途 |
---|---|---|
CHAR(M) | M個(gè)字節(jié),0 <= M <= 255 | 定義字符串 |
VARCHAR(M) | L+1個(gè)字節(jié)演痒,其中L+1 <= M 且 0 <= M <= 65535 | 變長(zhǎng)字符串 |
TINYTEXT | L+1個(gè)字節(jié)亲轨,其中L < 28 | 短文本字符串 |
TEXT | L+2個(gè)字節(jié),其中L < 216 | 長(zhǎng)文本數(shù)據(jù) |
MEDIUMTEXT | L+3個(gè)字節(jié)鸟顺,其中L < 224 | 二進(jìn)制形式的中等長(zhǎng)度文本數(shù)據(jù) |
LONGTEXT | L+4個(gè)字節(jié)惦蚊,其中L < 232 | 極大文本數(shù)據(jù) |
ENUM('value1','value2',...) | 1或2個(gè)字節(jié),取決于枚舉值的個(gè)數(shù)(最多65535個(gè)值) | |
SET('value1','value2',...) | 1讯嫂、2蹦锋、3、4或者8個(gè)字節(jié)欧芽,取決于set成員的數(shù)目(最多64個(gè)成員) |
- 時(shí)間類型
類型 | 存儲(chǔ)范圍 | 字節(jié)數(shù) | 格式 | 用途 |
---|---|---|---|---|
DATE | 1000-01-01 / 9999-12-31 | 3 | YYYY-MM-DD | 完整的日期值 |
TIME | '-838:59:59' / '838:59:59' | 3 | HH:MM:SS | 時(shí)間值或持續(xù)時(shí)間 |
YEAR | 1901 / 2155 | 1 | YYYY | 年份值 |
DATETIME | 1000-01-01 00:00:00 / 9999-12-31 23:59:59 | 8 | YYYY-MM-DD HH:MM:SS | 混合日期和時(shí)間值 |
TIMESTAMP | 1970-01-01 00:00:00 / 2037 年某時(shí) | 8 | YYYY-MM-DD HH:MM:SS | 混合日期和時(shí)間值莉掂,時(shí)間戳 |
2.數(shù)據(jù)表的操作
關(guān)鍵字最好大寫,這樣便于閱讀千扔≡髅睿可以用windows的cmd運(yùn)行工具對(duì)數(shù)據(jù)庫操作,前提是mysql的安裝目錄的子目錄bin的路徑添加導(dǎo)論系統(tǒng)變量PATH中曲楚,mysql -v
可以查看數(shù)據(jù)庫版本厘唾。登錄:mysql -u用戶名 -p密碼,例如 mysql -uroot -p123456
龙誊。
- 查看所有數(shù)據(jù)庫
SHOW DATABASES;
- 使用數(shù)據(jù)庫
USE 數(shù)據(jù)庫名
- 查看當(dāng)前使用的數(shù)據(jù)庫
SELECT database();
- 查看當(dāng)前的用戶
SELECT user();
- 查看當(dāng)前的時(shí)間
SELECT now();
- 查看當(dāng)前數(shù)據(jù)庫的數(shù)據(jù)表
SHOW TABLES;
- 查看其他數(shù)據(jù)庫的數(shù)據(jù)表
SHOW TABLES FROM 數(shù)據(jù)庫名;
- 創(chuàng)建數(shù)據(jù)表
CREATE TABLE 數(shù)據(jù)表名(
字段 類型 設(shè)定,
字段 類型 設(shè)定
);
- 查看數(shù)據(jù)表的結(jié)構(gòu)
SHOW COLUMNS FROM 數(shù)據(jù)表名
等效命令DESCRIBE 數(shù)據(jù)表名
- 查看數(shù)據(jù)表中的全部數(shù)據(jù)
SELECT * FROM 數(shù)據(jù)表名
3.數(shù)據(jù)記錄操作
- 創(chuàng)建一個(gè)簡(jiǎn)單的數(shù)據(jù)表
CREATE TABLE t1(
-> username VARCHAR(20) NOT NULL,
-> age TINYINT,
-> salary FLOAT(8,2)
-> );
- 查看剛才常見數(shù)據(jù)表的結(jié)構(gòu)
SHOW COLUMNS FROM t1;
Field | Type | Null | Key | Default | Extra |
---|---|---|---|---|---|
username | varchar(20) | NO | NULL | ||
age | tinyint(4) | YES | NULL | ||
salary | float(8,2) | YES | NULL |
- 插入一行數(shù)據(jù)
INSERT INTO t1 VALUES('Tom',20,56310.54);
INSERT t1(username,salary) VALUES('Jon',75654.35);
<font color="blue">INTO關(guān)鍵字可以省略抚垃,在表名后面不跟字段,默認(rèn)數(shù)據(jù)要插入所有字段的數(shù)據(jù)趟大,否則會(huì)報(bào)錯(cuò)</font>
- 查看剛才插入數(shù)據(jù)庫的所有數(shù)據(jù)
SELECT * FROM t1;
username | age | salary |
---|---|---|
Tom | 20 | 56310.54 |
Jon | NULL | 75654.35 |
- 創(chuàng)建自增長(zhǎng)且主鍵約束和唯一約束的數(shù)據(jù)表
CREATE TABLE t2(
-> id SMALLINT AUTO_INCREMENT PRIMARY KEY,
-> username VARCHAR(20) NOT NULL UNIQUE,
-> age TINYINT UNSIGNED,
-> sex ENUM('1','2','3') DEFAULT 3
-> );
AUTO_INCREMENT 自動(dòng)編號(hào)鹤树,必須與主鍵 PRIMARY KEY組合使用,默認(rèn)情況下逊朽,起始值為1魂迄,每次的增量為1。但是使用主鍵時(shí)惋耙,不一定用到自動(dòng)編號(hào)
- 查看剛才常見數(shù)據(jù)表的結(jié)構(gòu)
SELECT * FROM t2;
Field | Type | Null | Key | Default | Extra |
---|---|---|---|---|---|
id | smallint(6) | NO | PRI | NULL | auto_increment |
username | varchar(20) | NO | UNI | NULL | |
age | tinyint(3) unsigned | YES | NULL | ||
sex | enum('1','2','3') | YES | 3 |
唯一約束 UNIQUE 指的是該字段數(shù)據(jù)不能有重復(fù)捣炬,比如上面的數(shù)據(jù)表中就不能插入兩條username都為’tom‘的數(shù)據(jù)熊昌,即使這兩個(gè)人只是同名
五種約束
- NOT NULL 非空約束
- PRIMARY KEY 主鍵約束
- UNIQUE KEY 唯一約束
- DEFAULT 默認(rèn)約束
- NOT NULL 非空約束
外鍵約束
1.父表和子表必須使用相同的存儲(chǔ)引擎,而且禁止使用臨時(shí)表湿酸。
2.數(shù)據(jù)表的存儲(chǔ)引擎只能為InnoDB婿屹。
3.外鍵列和參照列必須具有相似的數(shù)據(jù)類型。其中數(shù)字的長(zhǎng)度或是有符號(hào)位都必須相同推溃;而字符的長(zhǎng)度則可以不同昂利。
4.外鍵列和參照列必須創(chuàng)建索引。如果外鍵列不存在索引的話铁坎,MySQL將自動(dòng)創(chuàng)建索引蜂奸。
-
創(chuàng)建一個(gè)省份表
CREATE TABLE province(
-> id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
-> pname VARCHAR(20) NOT NULL
-> );
-
查看創(chuàng)建表時(shí)的命令
SHOW CREATE TABLE province\G;
后面加上\G,可以過濾不必要的信息,方便查看硬萍。
Table: province
Create Table: CREATE TABLE `province` (
`id` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
`pname` varchar(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
可以看出符合存儲(chǔ)引擎為InnoDB的外鍵約束要求
-
創(chuàng)建一個(gè)子表用戶表
CREATE TABLE user(
-> id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
-> username VARCHAR(10) NOT NULL,
-> pid SMALLINT UNSIGNED,
-> FOREIGN KEY (pid) REFERENCES province (id)
-> );
pid 作為外鍵列扩所,province作為父表,其id為參照列朴乖,如果pid的數(shù)據(jù)類型和參照列的數(shù)據(jù)類型不同或者符號(hào)位不同祖屏,那么會(huì)報(bào)出150錯(cuò)誤,創(chuàng)建子表失敗买羞。
-
查看數(shù)據(jù)表的索引
SHOW INDEX FROM province\G;
*************************** 1. row ***************************
Table: province
Non_unique: 0
Key_name: PRIMARY
Seq_in_index: 1
Column_name: id
Collation: A
Cardinality: 0
Sub_part: NULL
Packed: NULL
Null:
Index_type: BTREE
Comment:
Index_comment:
SHOW INDEX FROM user\G;
*************************** 1. row ***************************
Table: user
Non_unique: 0
Key_name: PRIMARY
Seq_in_index: 1
Column_name: id
Collation: A
Cardinality: 0
Sub_part: NULL
Packed: NULL
Null:
Index_type: BTREE
Comment:
Index_comment:
*************************** 2. row ***************************
Table: user
Non_unique: 1
Key_name: pid
Seq_in_index: 1
Column_name: pid
Collation: A
Cardinality: 0
Sub_part: NULL
Packed: NULL
Null: YES
Index_type: BTREE
Comment:
Index_comment:
-
查看user的數(shù)據(jù)表創(chuàng)建命令
SHOW CREATE TABLE user\G;
*************************** 1. row ***************************
Table: user
Create Table: CREATE TABLE `user` (
`id` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
`username` varchar(10) NOT NULL,
`pid` smallint(5) unsigned DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `pid` (`pid`),
CONSTRAINT `user_ibfk_1` FOREIGN KEY (`pid`) REFERENCES `province` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
通過查看user表的創(chuàng)建命令袁勺,可以發(fā)現(xiàn)系統(tǒng)自動(dòng)為子表的pid創(chuàng)建了索引id,參考(reference)province表的id畜普。