1. 數值類型mysql
# MySQL支持全部標準SQL數值數據類型。這些類型包括嚴格數值數據類型(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及近似數值數據類型(FLOAT、REAL和DOUBLE PRECISION)。 # 關鍵字INT是INTEGER的同義詞,關鍵字DEC是DECIMAL的同義詞。 # MySQL支持的整數類型有TINYINT、MEDIUMINT和BIGINT。下面的表顯示了須要的每一個整數類型的存儲和範圍。 # 對於小數的表示,MYSQL分爲兩種方式:浮點數和定點數。浮點數包括float(單精度)和double(雙精度),而定點數只有decimal一種,在mysql中以字符串的形式存放,比浮點數更精確,適合用來表示貨幣等精度高的數據。 # BIT數據類型保存位字段值,而且支持MyISAM、MEMORY、InnoDB和BDB表。
# 對int類型的長度約束其實並無實際的效果,好比設置寬度爲5,約束只是在不足長度的時候的顯示寬度是5,而不是你只能存儲5位數 # 建立表一個是默認寬度的int,一個是指定寬度的int(5) mysql> create table t1 (id1 int,id2 int(5)); # 給t1中插入數據1,1 mysql> insert into t1 values (1,1); # 插入了比寬度更大的值,也不會報錯 mysql> insert into t1 values (111111,111111); # 修改id1字段 給字段添加一個unsigned表示無符號 mysql> alter table t1 modify id1 int unsigned;
# 建立表的三個字段分別爲float,double和decimal參數表示一共顯示5位,小數部分佔2位 mysql> create table t2 (id1 float(5,2),id2 double(5,2),id3 decimal(5,2)); # 向表中插入1.234,會發現4都被截斷了 mysql> insert into t2 values (1.234,1.234,1.234); # 向表中插入1.235發現數據雖然被截斷,可是遵循了四捨五入的規則 mysql> insert into t2 values (1.235,1.235,1.235); # 當對小數位沒有約束的時候,輸入超長的小數,會發現float和double的區別 mysql> insert into t3 values (1.2355555555555555555,1.2355555555555555555,1.2355555555555555555555); mysql> select * from t3; +---------+--------------------+------+ | id1 | id2 | id3 | +---------+--------------------+------+ | 1.234 | 1.234 | 1 | | 1.23556 | 1.2355555555555555 | 1 | +---------+--------------------+------+ 2 rows in set (0.00 sec) # float能精確道小數點後5位 # double能多精確一些位數,但仍存在不精確的狀況 # decimal默認是整數,經過設置最多能夠表示到小數點後30位
2. 字符串類型nginx
經常使用的字符串類型有:CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET。sql
最經常使用的就是char和varchar類型了數據庫
char:
能表示的長度較小,浪費存儲空間,讀寫速度快,是定長字符串,若是數據不足指定長度,會以空格填充;可是在顯示時,會去掉全部空格顯示,給用戶形成視覺欺騙
varchar:
能表示的長度大,能節省存儲空間,可是讀寫效率慢,是變長字符串;
越是長度固定,char比較省空間;越是長度不固定,varchar比較省空間
3. 時間類型架構
mysql> create table t4 (d date,t time,dt datetime); mysql> insert into t4 values (now(),now(),now()); mysql> select * from t4; +------------+----------+---------------------+ | d | t | dt | +------------+----------+---------------------+ | 2018-09-21 | 14:51:51 | 2018-09-21 14:51:51 | +------------+----------+---------------------+ 1 row in set (0.00 sec)
mysql> create table t5 (id1 timestamp); # 插入數據null,會自動插入當前時間的時間 mysql> insert into t5 values (null); mysql> select * from t5; +---------------------+ | id1 | +---------------------+ | 2018-09-21 14:56:50 | +---------------------+ 1 row in set (0.00 sec) # 添加一列 默認值是'0000-00-00 00:00:00' mysql> alter table t5 add id2 timestamp; # 手動修改新的列默認值爲當前時間 mysql> alter table t5 modify id2 timestamp default current_timestamp; # 插入null mysql> insert into t5 values (null,null); mysql> select * from t5; +---------------------+---------------------+ | id1 | id2 | +---------------------+---------------------+ | 2018-09-21 14:56:50 | 0000-00-00 00:00:00 | | 2018-09-21 14:59:31 | 2018-09-21 14:59:31 | +---------------------+---------------------+ 2 rows in set (0.00 sec) # 插入以下數字:19700101080001; mysql> insert into t5 values (19700101080001); mysql> select * from t6; +---------------------+ | t1 | +---------------------+ | 1970-01-01 08:00:01 | +---------------------+ 1 row in set (0.00 sec) # timestamp時間的下限是19700101080001 mysql> insert into t6 values (19700101080000);就會報錯 # timestamp時間的上限是2038-01-19 11:14:07 mysql> insert into t6 values ('2038-01-19 11:14:08');就會報錯
mysql> create table t6 (y year); mysql> insert into t6 values (2019); mysql> select * from t6; +------+ | y | +------+ | 2018 | +------+ 1 row in set (0.00 sec)
mysql> create table t8 (dt datetime); Query OK, 0 rows affected (0.01 sec) mysql> insert into t8 values ('2018-9-26 12:20:10'); Query OK, 1 row affected (0.01 sec) mysql> insert into t8 values ('2018/9/26 12+20+10'); Query OK, 1 row affected (0.00 sec) mysql> insert into t8 values ('20180926122010'); Query OK, 1 row affected (0.00 sec) mysql> insert into t8 values (20180926122010); Query OK, 1 row affected (0.00 sec) mysql> select * from t8; +---------------------+ | dt | +---------------------+ | 2018-09-26 12:20:10 | | 2018-09-26 12:20:10 | | 2018-09-26 12:20:10 | | 2018-09-26 12:20:10 | +---------------------+ 4 rows in set (0.00 sec)
4. set和enum類型ide
ENUM,在中文中叫枚舉類型,它的值範圍須要在建立表時經過枚舉方式顯示;ENUM只容許從值集合中選取單個值,不能一次取多個值;set和enum很是類似,也是字符串對象,裏面能夠包含0-64個成員。根據成員的不一樣,存儲上也有所不一樣。set類型能夠容許值集合中任意選擇1或多個元素進行組合。對超出範圍的內容將不容許注入,而對重複的值將進行自動去重。url
mysql> create table t10 (name char(20),gender enum('female','male')); # 選擇enum('female','male')中的一項做爲gender的值,能夠正常插入 mysql> insert into t10 values ('haha','male'); # 不能同時插入'male,female'兩個值,也不能插入不屬於'male,female'的值 mysql> insert into t10 values ('haha','male,female'); ERROR 1265 (01000): Data truncated for column 'gender' at row 1 mysql> create table t11 (name char(20),hobby set('抽菸','喝酒','燙頭','翻車')); # 能夠任意選擇set('抽菸','喝酒','燙頭','翻車')中的項,並自帶去重功能 mysql> insert into t11 values ('qian','燙頭,喝酒,燙頭'); mysql> select * from t11; +------+---------------+ | name | hobby | +------+---------------+ | yuan | 喝酒,燙頭 | +------+---------------+ 1 row in set (0.00 sec) # 不能選擇不屬於set('抽菸','喝酒','燙頭','翻車')中的項, mysql> insert into t11 values ('alex','燙頭,翻車,看妹子'); ERROR 1265 (01000): Data truncated for column 'hobby' at row 1
1. not null:not null表示不能爲空;null表示能夠爲空spa
mysql> create table t7 (id int not null); mysql> select * from t7; mysql> desc t7; +-------+---------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+---------+------+-----+---------+-------+ | id | int(11) | NO | | NULL | | +-------+---------+------+-----+---------+-------+ 1 row in set (0.00 sec) #不能向id列插入空元素。 mysql> insert into t7 values (null); ERROR 1048 (23000): Column 'id' cannot be null mysql> insert into t7 values (1);
2. default:約束某一列不爲空,若是這一列中常常有重複的內容,就須要咱們頻繁的插入重複內容,會給操做帶來負擔,咱們能夠選擇用默認值;建立列時能夠指定默認值,若是插入數據時未進行設置,就會自動添加默認值3d
mysql> create table t13 (id1 int not null,id2 int not null default 222); mysql> desc t13; +-------+---------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+---------+------+-----+---------+-------+ | id1 | int(11) | NO | | NULL | | | id2 | int(11) | NO | | 222 | | +-------+---------+------+-----+---------+-------+ 2 rows in set (0.01 sec) # 只向id1字段添加值,會發現id2字段會使用默認值填充 mysql> insert into t13 (id1) values (111); mysql> select * from t13; +-----+-----+ | id1 | id2 | +-----+-----+ | 111 | 222 | +-----+-----+ 1 row in set (0.00 sec) # id1字段不能爲空,因此不能單獨向id2字段填充值; mysql> insert into t13 (id2) values (223); ERROR 1364 (HY000): Field 'id1' doesn't have a default value # 向id1,id2中分別填充數據,id2的填充數據會覆蓋默認值 mysql> insert into t13 (id1,id2) values (112,223); mysql> select * from t13; +-----+-----+ | id1 | id2 | +-----+-----+ | 111 | 222 | | 112 | 223 | +-----+-----+ 2 rows in set (0.00 sec)
設置嚴格模式: 不支持對not null字段插入null值 不支持對自增加字段插入」值 不支持text字段有默認值 直接在mysql中生效(重啓失效): mysql>set sql_mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"; 配置文件添加(永久失效): sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"
3. UNIQUEcode
方法一: create table department1( id int, name varchar(20) unique, comment varchar(100) ); 方法二: create table department2( id int, name varchar(20), comment varchar(100), unique(name) );
mysql> create table t1(id int not null unique); mysql> desc t1; +-------+---------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+---------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | +-------+---------+------+-----+---------+-------+ 1 row in set (0.00 sec)
create table service( id int primary key auto_increment, name varchar(20), host varchar(15) not null, port int not null, unique(host,port) #聯合惟一 ); mysql> insert into service values -> (1,'nginx','192.168.0.10',80), -> (2,'haproxy','192.168.0.20',80), -> (3,'mysql','192.168.0.30',3306) -> ; Query OK, 3 rows affected (0.01 sec) Records: 3 Duplicates: 0 Warnings: 0 mysql> insert into service(name,host,port) values('nginx','192.168.0.10',80); ERROR 1062 (23000): Duplicate entry '192.168.0.10-80' for key 'host'
4. PRIMARY KEY
主鍵爲了保證表中的每一條數據的該字段都是表格中的惟一值,是用來獨一無二地確認一個表格中的每一行數據。 它能夠包含一個字段或多個字段。當主鍵包含多個欄位時,稱爲組合鍵 (Composite Key),也能夠叫聯合主鍵。主鍵能夠在建置新表格時設定 (運用 CREATE TABLE 語句),或是以改變現有的表格架構方式設定 (運用 ALTER TABLE)。
主鍵必須非空 + 惟一;能夠是單一字段,也能夠是多字段組合。
# 方法一:not null + unique mysql> create table department1( id int not null unique, #主鍵 name varchar(20) not null unique, comment varchar(100) ); # 方法二:某個字段後 + primary key mysql> create table department2( id int primary key, name varchar(20), comment varchar(100) ); # 方法三:全部字段後單獨定義primary key mysql> create table department3( id int, name varchar(20), comment varchar(100), primary key(id)); # 方法四:給已建成的表天價主鍵約束 mysql> alter table department4 modify id int primary key;
create table service( ip varchar(15), port char(5), service_name varchar(10) not null, primary key(ip,port) ); mysql> insert into service values ('172.16.45.10','3306','nginx'); ERROR 1062 (23000): Duplicate entry '172.16.45.10-3306' for key 'PRIMARY'
5. AUTO_INCREMENT
約束某列爲自增字段,被約束的字段同時必須被key約束
#不指定id,則自動增加 mysql> create table student( id int primary key auto_increment, name varchar(20), sex enum('male','female') default 'male' ); #對於自增的字段,在用delete刪除後,再插入值,該字段仍按照刪除前的位置繼續增加 mysql> delete from student; #應該用truncate清空表,比起delete一條一條地刪除記錄,truncate是直接清空表,在刪除大表時用它 mysql> truncate student;
# 建立完表後,修改自增字段的起始值 mysql> create table student(id int primary key auto_increment, name varchar(20), sex enum('male','female') default 'male'); # 修改自增字段起始值 mysql> alter table student auto_increment=3; # 此時給表中插入數據,id就會從3開始; # 在建立表時指定auto_increment的初始值,初始值的設置爲表選項,應放到括號外 mysql> create table student(id int primary key auto_increment, name varchar(20), sex enum('male','female') default 'male')auto_increment=3;
6. FOREIGNKEY
假設咱們要描述全部公司的員工,須要描述的屬性有這些 : 工號、姓名、部門;公司有3個部門,可是有1個億的員工,那意味着部門這個字段須要重複存儲,部門名字越長,越浪費;有一個解決方法:能夠定義一個部門表 而後讓員工信息表關聯該表,如何關聯,即foreign key
# 當表A的某個字段是惟一字段時,才能夠在表B中設置外鍵關聯表A mysql> create table A (dep_id int(4) unique, dep_name varchar(11)); # 建立表B,並關聯表A create table B (s_id int,name varchar(20),dep_id int,foreign key(dep_id) references A(dep_id));
# 表的類型是必須是InnoDB存儲引擎,且被關聯的字段即references指定的另一個表的字段,必須保證惟一 mysql> create table department(id int primary key, name varchar(20) not null)engine=innodb; #dpt_id外鍵,關聯父表(department主鍵id),同步更新,同步刪除 mysql> create table employee(id int primary key, name varchar(20) not null, dpt_id int, foreign key(dpt_id) references department(id) on delete cascade # 級連刪除 on update cascade # 級連更新)engine=innodb; #先往父表department中插入記錄 insert into department values(1,'教質部'),(2,'技術部'),(3,'人力資源部'); #再往子表employee中插入記錄 insert into employee values(1,'yuan',1),(2,'nezha',2),(3,'egon',2),(4,'alex',2),(5,'wusir',3),(6,'李沁洋',3),(7,'皮卡丘',3),(8,'程咬金',3),(9,'程咬銀',3); #刪父表department,子表employee中對應的記錄跟着刪 mysql> delete from department where id=2; mysql> select * from employee; +----+-----------+--------+ | id | name | dpt_id | +----+-----------+--------+ | 1 | yuan | 1 | | 5 | wusir | 3 | | 6 | 李沁洋 | 3 | | 7 | 皮卡丘 | 3 | | 8 | 程咬金 | 3 | | 9 | 程咬銀 | 3 | +----+-----------+--------+ 6 rows in set (0.00 sec) #更新父表department,子表employee中對應的記錄跟着改 mysql> update department set id=2 where id=3; Query OK, 1 row affected (0.01 sec) Rows matched: 1 Changed: 1 Warnings: 0 mysql> select * from employee; +----+-----------+--------+ | id | name | dpt_id | +----+-----------+--------+ | 1 | yuan | 1 | | 5 | wusir | 2 | | 6 | 李沁洋 | 2 | | 7 | 皮卡丘 | 2 | | 8 | 程咬金 | 2 | | 9 | 程咬銀 | 2 | +----+-----------+--------+ 6 rows in set (0.00 sec)
. cascade方式 在父表上update/delete記錄時,同步update/delete掉子表的匹配記錄 . set null方式 在父表上update/delete記錄時,將子表上匹配記錄的列設爲null,要注意子表的外鍵列不能爲not null . No action方式 若是子表中有匹配的記錄,則不容許對父表對應候選鍵進行update/delete操做 . Restrict方式 同no action, 都是當即檢查外鍵約束 . Set default方式 父表有變動時,子表將外鍵列設置成一個默認的值 但Innodb不能識別
# 建立數據庫 mysql> create database message; # 切換到數據庫中 mysql> use message; # 建立表 mysql> create table 表名(字段1 類型(寬度約束) 約束條件, 字段2 類型(寬度約束) 約束條件,字段3 類型(寬度約束) 約束條件); # 同一張表中字段名不能重複,寬度和約束條件可選,字段名和類型必須填 # 插入數據 # 指定字段進行數據插入 mysql> insert into staff_info (id,name,age,sex,phone,job) values (1,'haha',83,'female',13651054608,'IT'); # 不指定,就要把數據和字段類型對應 mysql> insert into staff_info values(2,'heihei',26,'male',13304320533,'Teacher');
查看錶結構有兩種方式:describe tablename;這種方法和desc tablename效果相同;能夠查看當前的表結構。雖然desc能夠查看錶結構,但輸出的信息不夠全面,爲了獲得更全面的表信息,有時候就須要查看建立表的SQL語句,使用show create table語法。除了能夠看到表定義以外,還能夠看到engine(存儲引擎)和charset(字符集)等信息。(\G選項的含義是是的記錄可以豎向排列,以便更好的顯示內容較長的記錄。)
mysql> describe staff_info; +-------+-----------------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+-----------------------+------+-----+---------+-------+ | id | int(11) | YES | | NULL | | | name | varchar(50) | YES | | NULL | | | age | int(3) | YES | | NULL | | | sex | enum('male','female') | YES | | NULL | | | phone | bigint(11) | YES | | NULL | | | job | varchar(11) | YES | | NULL | | +-------+-----------------------+------+-----+---------+-------+ 6 rows in set (0.00 sec) mysql> desc staff_info; +-------+-----------------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+-----------------------+------+-----+---------+-------+ | id | int(11) | YES | | NULL | | | name | varchar(50) | YES | | NULL | | | age | int(3) | YES | | NULL | | | sex | enum('male','female') | YES | | NULL | | | phone | bigint(11) | YES | | NULL | | | job | varchar(11) | YES | | NULL | | +-------+-----------------------+------+-----+---------+-------+ 6 rows in set (0.00 sec) mysql> show create table staff_info\G; *************************** 1. row *************************** Table: staff_info Create Table: CREATE TABLE `staff_info` ( `id` int(11) DEFAULT NULL, `name` varchar(50) DEFAULT NULL, `age` int(3) DEFAULT NULL, `sex` enum('male','female') DEFAULT NULL, `phone` bigint(11) DEFAULT NULL, `job` varchar(11) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8 1 row in set (0.01 sec) ERROR: No query specified
# 修改表名 alter table 表名 rename 新表名; # 增長字段 alter table 表名 add 字段名 數據類型[完整性約束條件]; # 刪除字段 alter table 表名 drop 字段名; # 修改字段 alter table 表名 modify 字段名 數據類型[完整性約束條件]; alter table 表名 change 舊字段名 新字段名 舊數據類型[約束條件]; alter table 表名 change 舊字段名 新字段名 新數據類型[約束條件]; # 修改字段排列順序/增長時指定字段位置 alter table 表名 add 字段名 類型[條件] first;表的第一列 alter table 表名 add 字段名 類型[條件] after 字段;在已存的某個字段後 alter table 表名 change 字段名 舊字段名 新字段名 新數據類型[約束條件] first; alter table 表名 modify 字段名 數據類型[約束條件] after 字段名;
alter操做非空、惟1、主鍵、外鍵:
create table t1(id int unique;name char(10) not null); # 去掉null約束 alter table t1 modify name char(10) null; # 添加null約束 alter table t1 modify name char(10) not null;
create table t(id int unique,name char(10) not null); # 去掉unique約束 alter table t drop index id; # 添加unique約束 alter table t modify id int unique;
# 建立一個數據表table_test: mysql> create table table_test( `id` varchar(100) NOT NULL, `name` varchar(100) NOT NULL, PRIMARY KEY (`name`) ); # 發現主鍵設置錯了,應該是id是主鍵,但現在表裏已經有好多數據了,不能刪除表再重建了,僅僅能在這基礎上改動表結構。 # 先刪除主鍵 alter table table_test drop primary key; # 再增長主鍵 alter table table_test add primary key(id); 注:在增長主鍵以前,必須先把反覆的id刪除掉。
# 建立press表 CREATE TABLE `press` (`id` int(11) NOT NULL,`name` char(10) DEFAULT NULL, PRIMARY KEY (`id`)) ; # 建立book表 CREATE TABLE `book` (`id` int(11) DEFAULT NULL,`bk_name` char(12) DEFAULT NULL, `press_id` int(11) NOT NULL,KEY `press_id` (`press_id`)) ; # 爲book表添加外鍵 alter table book add constraint fk_id foreign key(press_id)references press(id); # 刪除外鍵 alter table book drop foreign key fk_id;
drop table 表名;
1. 找出兩張表之間的關係
a. 先站在左表的角度找,看左表中是否有多條記錄能夠對應右表的一條記錄,若是是,則證實左表有一個foreign key關聯右表的一個字段,一般是id
b. 再從右表的角度去看,由表中是否有多條記錄對應左表的一條記錄,若是是,則證實右表有一個foreign key關聯左表的一個字段,一般是id
2. 表和表之間的關係
一對多:a中的狀況存在,則是:(左)多對一(右);b中的狀況存在,就是:(左)一對多(右);
多對多:若是a和b的狀況同時存在,則證實左右兩張表是一個雙向的一對多,即多對多,這時就須要新建一張表來專門存放兩者的關係
一對一:若是a和b都不成立,而是左表的一條記錄惟一對應右表的一條記錄,就在左表foreign key關聯右表的基礎上,將左表的外鍵字段設置成unique便可,反之亦然。
3. 創建表之間的關係
# 出版社和書 # 出版社表 create table press(id int primary key auto_increment,name varchar(20)); # 書籍表 create table book(id int primary key auto_increment,name varchar(20),press_id int not null,foreign key(press_id) references press(id) on delete cascade on update cascade); # 又或者是班級和學生,主機和機房,部門和員工等
# 出版社,做者,書籍 # 做者表 create table author(id int primary key auto_increment,name varchar(20)); # 多對多關係表 create table author2book(id int not null unique auto_increment, author_id int not null, book_id int not null, constraint fk_author foreign key(author_id) references author(id) on delete cascade on update cascade, constraint fk_book foreign key(book_id) references book(id) on delete cascade on update cascade, primary key(author_id,book_id) # 聯合主鍵 ); # 又或者服務和機器,一個機器能夠部署多個服務,一個服務也能夠部署到多個機器上
# 用戶和博客 # 用戶表 create table user(id int primary key auto_increment, name varchar(20) not null); # 博客表:foreignkey + unique create table blogs(id int primary key auto_incremen, url varchar(20) not null, name_id int unique, foreign key(name_id) referenses user(id) on delete cascade on update cascade);
MySQL的數據操做:DML;在MySQL管理軟件中,能夠經過SQL語句中的DML語言實現數據的操做,包括:使用INSERT插入數據,UPDATE實現數據更新,DELETE實現數據刪除,SELECT實現數據查詢。
順序插入數據:
insert into 表名 values (值1,值2,值3);
指定字段插入數據:
insert into 表名(字段1,字段2,...字段n) values(值1,值2,...值n);
插入多條數據:
insert into 表名 values
(值1,值2,...,值n),
(值1,值2,...,值n),
(值1,值2,...,值n);
插入查詢結果:
insert into 表名 (字段1,字段2,...,字段n) select (字段1,字段2,...,字段n) from 表2 where ...;
update 表名 set 字段1=值1,字段2=值2 where 條件;
delete from 表名 where 條件;