學(xué)習(xí)基礎(chǔ)mysql語(yǔ)法
發(fā)表時(shí)間:2023-09-02 來(lái)源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]前 言 mysql mysql語(yǔ)法--本篇學(xué)習(xí)都是通過(guò)使用Navicat Premium(數(shù)據(jù)庫(kù)管理工具),連接mysql數(shù)據(jù).本篇學(xué)習(xí)主要有兩個(gè)部分: 一、創(chuàng)建用戶,創(chuàng)建數(shù)據(jù)庫(kù),給用戶分配權(quán)限,刪除用戶權(quán)限! 二、MYSQL中常見(jiàn)的數(shù)據(jù)類(lèi)型 三、表-創(chuàng)建表、主鍵、外鍵 ...
前 言
mysql
mysql語(yǔ)法--本篇學(xué)習(xí)都是通過(guò)使用Navicat Premium(數(shù)據(jù)庫(kù)管理工具),連接mysql數(shù)據(jù).
本篇學(xué)習(xí)主要有兩個(gè)部分:
一、創(chuàng)建用戶,創(chuàng)建數(shù)據(jù)庫(kù),給用戶分配權(quán)限,刪除用戶權(quán)限。
二、MYSQL中常見(jiàn)的數(shù)據(jù)類(lèi)型
三、表-創(chuàng)建表、主鍵、外鍵
四、數(shù)據(jù)庫(kù)設(shè)計(jì)的三大范式
以下所有代碼全部在新建查詢表里面使用mysql語(yǔ)法編輯。
1、創(chuàng)建用戶,創(chuàng)建數(shù)據(jù)庫(kù),給用戶分配權(quán)限,刪除用戶權(quán)限。
|
/* SQL 多行注釋 */
-- SQL 單行注釋
創(chuàng)建用戶:CREATE USER '用戶名'@'主機(jī)名' IDENTIFIED BY '密碼';
主機(jī)名可以為空,為空默認(rèn)為%權(quán)限,表示所有主機(jī)可連接。
給用戶分配權(quán)限: GRANT 權(quán)限名 ON 數(shù)據(jù)庫(kù)名.表明 TO 用戶名@主機(jī)名
刪除用戶權(quán)限: REVOKE 權(quán)限名 ON 數(shù)據(jù)庫(kù)名.表明 FROM 用戶名@主機(jī)名;
創(chuàng)建數(shù)據(jù)庫(kù): CREATE DATABASE [IF NOT EXISTS] 數(shù)據(jù)庫(kù)名[CHARACTER SET[=] 'UTF8'];
<<<如果省略 [IF NOT EXISTS] 在重復(fù)創(chuàng)建數(shù)據(jù)庫(kù)時(shí),會(huì)報(bào)錯(cuò)!
查詢本機(jī)中所有的數(shù)據(jù)庫(kù):SHOW DATABASES
↓使用mydb這個(gè)數(shù)據(jù)庫(kù)↓,表示下面的查詢都將默認(rèn)針對(duì)mydb數(shù)據(jù)庫(kù)
USE mydb;
查詢數(shù)據(jù)庫(kù)中所有數(shù)據(jù)表: SHOW TABLES [FROM 數(shù)據(jù)庫(kù)]
2 MYSQL中常見(jiàn)的數(shù)據(jù)類(lèi)型
|
一、字符型:
① CHAR(N):固定N個(gè)字符長(zhǎng)度的字符串,如果長(zhǎng)度不夠會(huì)自動(dòng)空格補(bǔ)齊;
② VARCHAR(N):存儲(chǔ)可邊長(zhǎng)度的字符節(jié)。常用的 0~255;
③ TEXT:存儲(chǔ)可變長(zhǎng)度的字符串。(常用語(yǔ)發(fā)布文章等大段內(nèi)容)0~((2^16-1)*10^2);
④ TINYTEXT:0~((2^8-1)*10);
⑤ MEDIUMTEXT:0~((2^24-1)*10^3);
⑥ LINGTEXT:0~((2^32-1)*10^4);
⑦ enum("男","女"):枚舉類(lèi)型,字段只能容納枚舉出的數(shù)據(jù)。
二、整形:
① TINYINT: 無(wú)符號(hào)0~2^8-1 有符號(hào) -2^7~2^7-1;
② SMALLINT: 無(wú)符號(hào)0~2^16-1 有符號(hào) -2^15~2^15-1;
③ MEDIUMINT: 無(wú)符號(hào)0~2^24-1 有符號(hào) -2^23~2^23-1;
④ INT: 無(wú)符號(hào)0~2^32-1 有符號(hào) -2^31~2^31-1 最常用!
⑤ BIGINT: 無(wú)符號(hào)0~2^64-1 有符號(hào) -2^63~2^63-1;
三、浮點(diǎn)型:
① FLOAT: 可以精確到小數(shù)點(diǎn)后7位有效數(shù)字;
② DOUBLE: 可以精確到小數(shù)點(diǎn)后15位到16位有效數(shù)字;
四、日期時(shí)間數(shù)據(jù)類(lèi)型
注意:由于時(shí)間存儲(chǔ)使用字符串或者時(shí)間戳存儲(chǔ),所以數(shù)據(jù)庫(kù)中幾乎不用日期類(lèi)型。
① DATE:存儲(chǔ)日期和時(shí)間數(shù)據(jù)
② TIMESTAMP:比DATE更精確
【創(chuàng)建表】:
CREATE TABLE [IF NOT EXISTS] 表單名(
IF NOT EXISTS 可以省略,省略后重復(fù)創(chuàng)建報(bào)錯(cuò).如果不省略,則創(chuàng)建時(shí)會(huì)檢測(cè)表是否已存在,如果表存在則不再執(zhí)行創(chuàng)建語(yǔ)句
定義列:列名 數(shù)據(jù)類(lèi)型 列表關(guān)鍵字
。
常用的列定義關(guān)鍵字:
① UNSIGNED: 設(shè)置列表為無(wú)符號(hào)列。只能設(shè)置類(lèi)型為數(shù)字類(lèi)型的列
② AUTO_INCREMENT PRIMARY KEY 設(shè)置列為自動(dòng)增長(zhǎng)列。自動(dòng)增長(zhǎng)列必須是主鍵。
③ NOT null:設(shè)置列為非空約束
④ UNIQUE:設(shè)置唯一性約束。該字段不能出現(xiàn)重復(fù)值。
⑤ DEFAULT: 設(shè)置默認(rèn)值約束。
【主鍵】:
1、主鍵的注意事項(xiàng)? 主鍵默認(rèn)為空!主鍵默認(rèn)唯一性約束!
只有主鍵才能設(shè)置自動(dòng)增長(zhǎng)(主鍵不一定自動(dòng)增長(zhǎng),自動(dòng)增長(zhǎng)必須是主鍵)
2、設(shè)置主鍵的方式?
① 在列定義是設(shè)置: age SMALLINT(3) PRIMARY KEY,
② 在列定義完成后設(shè)置: PRIMARY KEY(age),
【外鍵】
1、設(shè)置外鍵有哪些注意事項(xiàng)
① 只有innodb的數(shù)據(jù)庫(kù)引擎支持外鍵,修改mysql.ini文件:default-storage-engine=INNODB
② 外鍵與參照列的數(shù)據(jù)類(lèi)型必須相同。(數(shù)值型要求長(zhǎng)度和無(wú)符號(hào)都相同,字符串要求類(lèi)型相同,長(zhǎng)度可以不同。)
③ 設(shè)置外鍵的字段必須要有索引。如果沒(méi)有索引,設(shè)置外鍵時(shí)會(huì)自動(dòng)生成一個(gè)索引。
2、設(shè)置外鍵的語(yǔ)法?
[CONSTRAINT 外鍵名] FOREIGN KEY (外鍵字段) REFERENCES 參照表(參照字段) [ON DELETE SET NULL on update CASCADE]-- 設(shè)置參照完整性
3、外鍵約束的參照完整性操作?
參照操作:當(dāng)對(duì)參照表的參照字段進(jìn)行刪除或者更新是,外鍵表中的外鍵如何應(yīng)對(duì)。
參照操作可選值:restrict 拒絕參照表刪除或更新參照字段;(默認(rèn))
NO ACTION 與 restrict一樣,但這個(gè)指令只在mysql生效;
cascade 刪除或更新參照表的參照字段時(shí),外鍵表的記錄同步刪除或更新;(外鍵表和參照表同步)
set null 刪除或更新參照表的參照字段時(shí),外鍵表的外鍵設(shè)為null;
CREATE TABLE IF NOT EXISTS tb1(
-- IF NOT EXISTS 可以省略,省略后重復(fù)創(chuàng)建報(bào)錯(cuò).如果不省略,則創(chuàng)建時(shí)會(huì)檢測(cè)表是否已存在,如果表存在則不再執(zhí)行創(chuàng)建語(yǔ)句id INT(3),
`name` VARCHAR(255) NOT null, -- name是系統(tǒng)關(guān)鍵字,所以使用反引號(hào)``包裹age SMALLINT(3) AUTO_INCREMENT PRIMARY KEY,
lalala INT UNIQUE,
height DOUBLE(3,2) DEFAULT 1.2 -- 設(shè)置默認(rèn)值約束:默認(rèn)值為1.2-- PRIMARY KEY(age));create table if not exists classes(
id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
classname VARCHAR(255) NOT NULL );CREATE table if not EXISTS `user`(
id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
clsId INT UNSIGNED,
`name` VARCHAR(255) NOT NULL, CONSTRAINT user_fk_classes FOREIGN KEY (clsid) REFERENCES classes(id) ON DELETE SET NULL on update CASCADE)-- auto_increment-- 顯示表結(jié)構(gòu)SHOW TABLES;-- 顯示表內(nèi)容結(jié)構(gòu)SHOW COLUMNS FROM TB1;-- 現(xiàn)實(shí)表的建表語(yǔ)句show create TABLE tb1;-- 刪除表DROP TABLE IF EXISTS TB1;DROP TABLE IF EXISTS classes;DROP TABLE IF EXISTS `user`;-- 修改表名 ALTER table tb1 rename tb2;-- 修改字段 列-- alter table 表名 change 舊列名 新列名 列定義 [first after某一列]-- first 將這個(gè)字段調(diào)整為表格第一列; after某一列: 將這個(gè)字段放到某一列后面alter table tb1 change height width VARCHAR(200) not NULL FIRST;
-- 刪除表中某一列alter table tb1 drop name;-- 新增一列:必選部分:alter table tb1 add haha DOUBLE(8,2)alter table tb1 add haha DOUBLE(8,2) DEFAULT 1.2 after age;-- 新增多列:不能調(diào)整列的位置,只能插在最后。alter table tb1 add (
ha1 DOUBLE(3,2) UNSIGNED,
ha2 VARCHAR(255)
);-- 同時(shí)修改多表明 rename table tb3 to tb1[,`USER`to user1];rename table tb2 to tb1,`USER`to user1;-- 增加主鍵約束alter table tb1 add PRIMARY KEY(id);-- 刪除主鍵約束alter table tb1 drop PRIMARY KEY;-- 新增唯一性約束ALTER table tb1 add unique key(ha1);-- 刪除唯一性約束:由于創(chuàng)建唯一性約束會(huì)默認(rèn)創(chuàng)建索引,所以刪除時(shí),需刪除索引ALTER table tb1 drop index ha1;
-- 設(shè)置默認(rèn)值約束:前提必須設(shè)置default 屬性ALTER table tb1 alter ha1 set default 20;-- 刪除默認(rèn)值約束ALTER table tb1 alter haha drop default;-- 設(shè)置外鍵約束 必選部分 alter table tb1 add foreign key (clsid)REFERENCES classes(id)alter table tb1 add constraint waijianming foreign key (clsid)REFERENCES classes(id) ON DELETE SET NULL on update CASCADE;-- 刪除外鍵約束,由于常見(jiàn)外鍵時(shí)會(huì)生成索引,所以刪除外鍵后,需要?jiǎng)h索引。alter table tb1 drop foreign key waijianming;alter table tb1 drop INDEX waijianming;
SHOW COLUMNS FROM TB1;
1、第一范式(1NF):數(shù)據(jù)表中的每一列(字段),必須是不可拆分的最小單元。也就是確保每一列的原子性。
例如: userInfo:'山東省煙臺(tái)市 13181621008'
userads:'山東省煙臺(tái)市' userTel:'13181621008'
2、第二范式(2NF):滿足1NF后,要求:表中的所有列,都必須依賴(lài)于主鍵,而不能有任何一列與主鍵沒(méi)有關(guān)系。 也就是說(shuō),一個(gè)表只描述一件事情。
例如: 訂單表,只能描述訂單相關(guān)的信息,所以所有的字段都必須與訂單ID相關(guān);
產(chǎn)品表,只能描述產(chǎn)品相關(guān)的信息,所以所有的字段都必須與產(chǎn)品ID相關(guān);
因此: 不能在同一張表中同事出現(xiàn)訂單信息與產(chǎn)品信息。
3、第三范式(3NF):表中的每一列都要與主鍵直接相關(guān),而不是間接相關(guān)。(表中的每一列,只能依賴(lài)于主鍵)。
例如:訂單表中,需要有客戶相關(guān)信息,在分理處客戶表之后。訂單表中,只需要有一個(gè)用戶ID即可。而不能有其他的客戶信息。因?yàn)椋渌挠脩粜畔⑹侵苯雨P(guān)聯(lián)于用戶ID,而不是關(guān)聯(lián)于訂單ID。
【第二范式與第三范式的本質(zhì)區(qū)別】
在于沒(méi)有分出兩張表,第二范式是說(shuō)一張表中包含了多種不同實(shí)體的屬性,那么必須要分成多張表。
第三范式是要求,已經(jīng)分好了多張表的化,那么,一張表中只能有另一張表中的ID(主鍵),而不能有其他的任何信息(其他的任何信息,一律用主鍵在另一表查詢)
學(xué)習(xí)時(shí)候的筆記,可能會(huì)有一些錯(cuò)誤的地方,歡迎各位的批評(píng)指點(diǎn)。
反思,復(fù)盤(pán),每天收獲一點(diǎn)---------------------期待更好的自己
以上就是學(xué)習(xí)基礎(chǔ)mysql語(yǔ)法的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!
學(xué)習(xí)教程快速掌握從入門(mén)到精通的SQL知識(shí)。