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

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畜普。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末期丰,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子吃挑,更是在濱河造成了極大的恐慌咐汞,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,544評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件儒鹿,死亡現(xiàn)場(chǎng)離奇詭異化撕,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)约炎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門植阴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人圾浅,你說我怎么就攤上這事掠手。” “怎么了狸捕?”我有些...
    開封第一講書人閱讀 162,764評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵喷鸽,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我灸拍,道長(zhǎng)做祝,這世上最難降的妖魔是什么砾省? 我笑而不...
    開封第一講書人閱讀 58,193評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮混槐,結(jié)果婚禮上编兄,老公的妹妹穿的比我還像新娘。我一直安慰自己声登,他們只是感情好狠鸳,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著悯嗓,像睡著了一般件舵。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上脯厨,一...
    開封第一講書人閱讀 51,182評(píng)論 1 299
  • 那天铅祸,我揣著相機(jī)與錄音,去河邊找鬼俄认。 笑死,一個(gè)胖子當(dāng)著我的面吹牛洪乍,可吹牛的內(nèi)容都是我干的眯杏。 我是一名探鬼主播,決...
    沈念sama閱讀 40,063評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼壳澳,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼岂贩!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起巷波,我...
    開封第一講書人閱讀 38,917評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤萎津,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后抹镊,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體锉屈,經(jīng)...
    沈念sama閱讀 45,329評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評(píng)論 2 332
  • 正文 我和宋清朗相戀三年垮耳,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了颈渊。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,722評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡终佛,死狀恐怖俊嗽,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情铃彰,我是刑警寧澤绍豁,帶...
    沈念sama閱讀 35,425評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站牙捉,受9級(jí)特大地震影響竹揍,放射性物質(zhì)發(fā)生泄漏敬飒。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評(píng)論 3 326
  • 文/蒙蒙 一鬼佣、第九天 我趴在偏房一處隱蔽的房頂上張望驶拱。 院中可真熱鬧,春花似錦晶衷、人聲如沸蓝纲。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽税迷。三九已至,卻和暖如春锹漱,著一層夾襖步出監(jiān)牢的瞬間箭养,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評(píng)論 1 269
  • 我被黑心中介騙來泰國打工哥牍, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留毕泌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,729評(píng)論 2 368
  • 正文 我出身青樓嗅辣,卻偏偏與公主長(zhǎng)得像撼泛,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子澡谭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容

  • 1愿题、MySQL啟動(dòng)和關(guān)閉(安裝及配置請(qǐng)參照百度經(jīng)驗(yàn)蛙奖,這里不再記錄。MySQL默認(rèn)端口號(hào):3306仔夺;默認(rèn)數(shù)據(jù)類型格式...
    強(qiáng)壯de西蘭花閱讀 648評(píng)論 0 1
  • 什么是SQL數(shù)據(jù)庫: SQL是Structured Query Language(結(jié)構(gòu)化查詢語言)的縮寫囚灼。SQL是...
    西貝巴巴閱讀 1,810評(píng)論 0 10
  • 圖片發(fā)自簡(jiǎn)書App 每個(gè)人都曾愛過一個(gè)人灶体,也許成了愛人蝎抽,也許成了過往 我認(rèn)識(shí)滿哥的時(shí)候是在盼盼的生日聚會(huì)上,他是盼...
    Gardenia梔子閱讀 597評(píng)論 1 0
  • 這是一篇無標(biāo)題的文章,因?yàn)檫€沒想好寫什么瓢宦。 之前有過一個(gè)賬號(hào)驮履,寫過幾句話,這次換了微信登錄倒戏,只是希望能更方便一點(diǎn)恐似。...
    大蝦_小喵閱讀 202評(píng)論 0 0
  • 寒日吟 衙齋森森尺櫝冷,寒月攏霜布衾涼葛闷。 半窗塵輝山河遠(yuǎn)双藕,一思惆悵訴離殤。 ???
    園_48c5閱讀 173評(píng)論 0 0