寫給新手的Mysql入門指南(一)

1.數據類型

根據項目的實際需要使用合適的數據類型,這也是數據優化的操作

  • 整型
類型 存儲范圍 字節數
TINYINT 有符號值:-128 到 127 (-27 到 27-1)
無符號值:0 到 255 (0 到 28-1)
1
SMALLINT 有符號值:-32768 到 32767 (-215 到 215-1)
無符號值:0 到 65535 (0 到 216-1)
2
MEDIUMINT 有符號值:-8388608 到 8388607 (-223 到 223-1)
無符號值:0 到 16777215 (0 到 224-1)
3
INT 有符號值:-2147483648 到 2147483647 (-231 到 231-1)
無符號值:0 到 4294967295 (0 到 232-1)
4
BIGINT 有符號值:-9223372036854775808 到9223372036854775807 (-263 到 263-1)
無符號值:0 到 18446744073709551615 (0 到 264-1)
8
  • 浮點型
類型 存儲范圍 字節數
FLOAT[(M,D)] -3.402823466E+38 到 -1.175494351E-38、 0 和 1.175494351E-38 到 3.402823466E+38。
M是數字的總位數,D是小數點后面的位數。如果M和D被省略,則根據硬件允許的限制來保存值。單精度浮點數精確到大約7位小數位。
4
DOUBLE[(M,D)] -1.7976931348623157E+308 到 -2.2250738585072014E-308、 0 和 2.2250738585072014E-308 到 1.7976931348623157E+308 8
  • 字符型
類型 存儲需求 用途
CHAR(M) M個字節,0 <= M <= 255 定義字符串
VARCHAR(M) L+1個字節,其中L+1 <= M 且 0 <= M <= 65535 變長字符串
TINYTEXT L+1個字節,其中L < 28 短文本字符串
TEXT L+2個字節,其中L < 216 長文本數據
MEDIUMTEXT L+3個字節,其中L < 224 二進制形式的中等長度文本數據
LONGTEXT L+4個字節,其中L < 232 極大文本數據
ENUM('value1','value2',...) 1或2個字節,取決于枚舉值的個數(最多65535個值)
SET('value1','value2',...) 1、2、3、4或者8個字節,取決于set成員的數目(最多64個成員)
  • 時間類型
類型 存儲范圍 字節數 格式 用途
DATE 1000-01-01 / 9999-12-31 3 YYYY-MM-DD 完整的日期值
TIME '-838:59:59' / '838:59:59' 3 HH:MM:SS 時間值或持續時間
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 混合日期和時間值
TIMESTAMP 1970-01-01 00:00:00 / 2037 年某時 8 YYYY-MM-DD HH:MM:SS 混合日期和時間值,時間戳

2.數據表的操作

關鍵字最好大寫,這樣便于閱讀??梢杂脀indows的cmd運行工具對數據庫操作,前提是mysql的安裝目錄的子目錄bin的路徑添加導論系統變量PATH中,mysql -v可以查看數據庫版本。登錄:mysql -u用戶名 -p密碼,例如 mysql -uroot -p123456

  • 查看所有數據庫 SHOW DATABASES;
  • 使用數據庫 USE 數據庫名
  • 查看當前使用的數據庫 SELECT database();
  • 查看當前的用戶 SELECT user();
  • 查看當前的時間 SELECT now();
  • 查看當前數據庫的數據表 SHOW TABLES;
  • 查看其他數據庫的數據表 SHOW TABLES FROM 數據庫名;
  • 創建數據表
CREATE TABLE 數據表名(
字段 類型 設定,
字段 類型 設定
);
  • 查看數據表的結構 SHOW COLUMNS FROM 數據表名 等效命令 DESCRIBE 數據表名
  • 查看數據表中的全部數據 SELECT * FROM 數據表名

3.數據記錄操作

  • 創建一個簡單的數據表
CREATE TABLE t1(
    -> username VARCHAR(20) NOT NULL,
    -> age TINYINT,
    -> salary FLOAT(8,2)
    -> );
  • 查看剛才常見數據表的結構
    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
  • 插入一行數據
    INSERT INTO t1 VALUES('Tom',20,56310.54);
    INSERT t1(username,salary) VALUES('Jon',75654.35);

<font color="blue">INTO關鍵字可以省略,在表名后面不跟字段,默認數據要插入所有字段的數據,否則會報錯</font>

  • 查看剛才插入數據庫的所有數據
    SELECT * FROM t1;
username age salary
Tom 20 56310.54
Jon NULL 75654.35
  • 創建自增長且主鍵約束和唯一約束的數據表
 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 自動編號,必須與主鍵 PRIMARY KEY組合使用,默認情況下,起始值為1,每次的增量為1。但是使用主鍵時,不一定用到自動編號

  • 查看剛才常見數據表的結構
    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 指的是該字段數據不能有重復,比如上面的數據表中就不能插入兩條username都為’tom‘的數據,即使這兩個人只是同名

五種約束

  • NOT NULL 非空約束
  • PRIMARY KEY 主鍵約束
  • UNIQUE KEY 唯一約束
  • DEFAULT 默認約束
  • NOT NULL 非空約束

外鍵約束

  • 1.父表和子表必須使用相同的存儲引擎,而且禁止使用臨時表。

  • 2.數據表的存儲引擎只能為InnoDB。

  • 3.外鍵列和參照列必須具有相似的數據類型。其中數字的長度或是有符號位都必須相同;而字符的長度則可以不同。

  • 4.外鍵列和參照列必須創建索引。如果外鍵列不存在索引的話,MySQL將自動創建索引。

  • 創建一個省份表
 CREATE TABLE province(
    -> id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
    -> pname VARCHAR(20) NOT NULL
    -> );
  • 查看創建表時的命令

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

可以看出符合存儲引擎為InnoDB的外鍵約束要求

  • 創建一個子表用戶表
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的數據類型和參照列的數據類型不同或者符號位不同,那么會報出150錯誤,創建子表失敗。

  • 查看數據表的索引

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的數據表創建命令

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表的創建命令,可以發現系統自動為子表的pid創建了索引id,參考(reference)province表的id。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,546評論 6 533
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,570評論 3 418
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 176,505評論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,017評論 1 313
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,786評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,219評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,287評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,438評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,971評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,796評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,995評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,540評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,230評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,662評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,918評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,697評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,991評論 2 374

推薦閱讀更多精彩內容

  • 1、MySQL啟動和關閉(安裝及配置請參照百度經驗,這里不再記錄。MySQL默認端口號:3306;默認數據類型格式...
    強壯de西蘭花閱讀 673評論 0 1
  • 什么是SQL數據庫: SQL是Structured Query Language(結構化查詢語言)的縮寫。SQL是...
    西貝巴巴閱讀 1,833評論 0 10
  • 圖片發自簡書App 每個人都曾愛過一個人,也許成了愛人,也許成了過往 我認識滿哥的時候是在盼盼的生日聚會上,他是盼...
    Gardenia梔子閱讀 609評論 1 0
  • 這是一篇無標題的文章,因為還沒想好寫什么。 之前有過一個賬號,寫過幾句話,這次換了微信登錄,只是希望能更方便一點。...
    大蝦_小喵閱讀 203評論 0 0
  • 寒日吟 衙齋森森尺櫝冷,寒月攏霜布衾涼。 半窗塵輝山河遠,一思惆悵訴離殤。 ???
    園_48c5閱讀 178評論 0 0