六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

學習基礎mysql語法

[摘要]前 言 mysql  mysql語法--本篇學習都是通過使用Navicat Premium(數據庫管理工具),連接mysql數據.本篇學習主要有兩個部分:   一、創建用戶,創建數據庫,給用戶分配權限,刪除用戶權限。   二、MYSQL中常見的數據類型   三、表-創建表、主鍵、外鍵 ...

前 言

mysql

 mysql語法--本篇學習都是通過使用Navicat Premium(數據庫管理工具,連接mysql數據.

本篇學習主要有兩個部分:

   一、創建用戶,創建數據庫,給用戶分配權限,刪除用戶權限。

   二、MYSQL中常見的數據類型

   三、表-創建表、主鍵、外鍵

   四、數據庫設計的三大范式

以下所有代碼全部在新建查詢表里面使用mysql語法編輯。

1、創建用戶,創建數據庫,給用戶分配權限,刪除用戶權限。
/* SQL 多行注釋 */
-- SQL 單行注釋

創建用戶:CREATE USER '用戶名'@'主機名' IDENTIFIED BY '密碼';
      主機名可以為空,為空默認為%權限,表示所有主機可連接。
給用戶分配權限: GRANT 權限名 ON 數據庫名.表明 TO 用戶名@主機名
刪除用戶權限: REVOKE 權限名 ON 數據庫名.表明 FROM 用戶名@主機名;
創建數據庫: CREATE DATABASE [IF NOT EXISTS] 數據庫名[CHARACTER SET[=] 'UTF8'];
     <<<如果省略 [IF NOT EXISTS] 在重復創建數據庫時,會報錯!
查詢本機中所有的數據庫:SHOW DATABASES

使用mydb這個數據庫↓,表示下面的查詢都將默認針對mydb數據庫
USE mydb;
查詢數據庫中所有數據表: SHOW TABLES [FROM 數據庫]

2 MYSQL中常見的數據類型
   
一、字符型:

   ① CHAR(N):固定N個字符長度的字符串,如果長度不夠會自動空格補齊;
   ② VARCHAR(N):存儲可邊長度的字符節。常用的 0~255;
   ③ TEXT:存儲可變長度的字符串。(常用語發布文章等大段內容)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("男","女"):枚舉類型,字段只能容納枚舉出的數據。

二、整形:

① TINYINT: 無符號0~2^8-1 有符號 -2^7~2^7-1;
② SMALLINT: 無符號0~2^16-1 有符號 -2^15~2^15-1;
③ MEDIUMINT: 無符號0~2^24-1 有符號 -2^23~2^23-1;
④ INT: 無符號0~2^32-1 有符號 -2^31~2^31-1 最常用!
⑤ BIGINT: 無符號0~2^64-1 有符號 -2^63~2^63-1;

三、浮點型:

① FLOAT: 可以精確到小數點后7位有效數字;
② DOUBLE: 可以精確到小數點后15位到16位有效數字;

四、日期時間數據類型

注意:由于時間存儲使用字符串或者時間戳存儲,所以數據庫中幾乎不用日期類型。
① DATE:存儲日期和時間數據
② TIMESTAMP:比DATE更精確

3、表-創建表、主鍵、外鍵
   
【創建表

  CREATE TABLE [IF NOT EXISTS] 表單名(
  IF NOT EXISTS 可以省略,省略后重復創建報錯.如果不省略,則創建時會檢測表是否已存在,如果表存在則不再執行創建語句
  定義列:列名 數據類型 列表關鍵字
  )
  常用的列定義關鍵字:
   ① UNSIGNED: 設置列表為無符號列。只能設置類型為數字類型的列
   ② AUTO_INCREMENT PRIMARY KEY 設置列為自動增長列。自動增長列必須是主鍵。
   ③ NOT null:設置列為非空約束
   ④ UNIQUE:設置唯一性約束。該字段不能出現重復值。
   ⑤ DEFAULT: 設置默認值約束。


【主鍵

   1、主鍵的注意事項? 主鍵默認為空!主鍵默認唯一性約束!
只有主鍵才能設置自動增長(主鍵不一定自動增長,自動增長必須是主鍵)

  2、設置主鍵的方式?
   ① 在列定義是設置: age SMALLINT(3) PRIMARY KEY,
   ② 在列定義完成后設置: PRIMARY KEY(age),

【外鍵】
   1、設置外鍵有哪些注意事項
   ① 只有innodb的數據庫引擎支持外鍵,修改mysql.ini文件:default-storage-engine=INNODB
   ② 外鍵與參照列的數據類型必須相同。(數值型要求長度和無符號都相同,字符串要求類型相同,長度可以不同。)
   ③ 設置外鍵的字段必須要有索引。如果沒有索引,設置外鍵時會自動生成一個索引。

   2、設置外鍵的語法?
   [CONSTRAINT 外鍵名] FOREIGN KEY (外鍵字段) REFERENCES 參照表(參照字段) [ON DELETE SET NULL on update CASCADE]-- 設置參照完整性
  

   3、外鍵約束的參照完整性操作?
   參照操作:當對參照表的參照字段進行刪除或者更新是,外鍵表中的外鍵如何應對。
   參照操作可選值:restrict 拒絕參照表刪除或更新參照字段;(默認)
   NO ACTION 與 restrict一樣,但這個指令只在mysql生效;
   cascade 刪除或更新參照表的參照字段時,外鍵表的記錄同步刪除或更新;(外鍵表和參照表同步)
   set null 刪除或更新參照表的參照字段時,外鍵表的外鍵設為null;
  

CREATE TABLE IF NOT EXISTS tb1( 
-- IF NOT EXISTS 可以省略,省略后重復創建報錯.如果不省略,則創建時會檢測表是否已存在,如果表存在則不再執行創建語句id INT(3),
    `name` VARCHAR(255) NOT null, -- name是系統關鍵字,所以使用反引號``包裹age SMALLINT(3) AUTO_INCREMENT PRIMARY KEY,
    lalala INT UNIQUE,
 height DOUBLE(3,2) DEFAULT 1.2 -- 設置默認值約束:默認值為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-- 顯示表結構SHOW TABLES;-- 顯示表內容結構SHOW COLUMNS FROM TB1;-- 現實表的建表語句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 將這個字段調整為表格第一列; after某一列: 將這個字段放到某一列后面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;-- 新增多列:不能調整列的位置,只能插在最后。alter table tb1 add (
    ha1 DOUBLE(3,2) UNSIGNED,
    ha2 VARCHAR(255)
);-- 同時修改多表明  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);-- 刪除唯一性約束:由于創建唯一性約束會默認創建索引,所以刪除時,需刪除索引ALTER table tb1 drop index ha1;    
-- 設置默認值約束:前提必須設置default 屬性ALTER table tb1 alter ha1 set default 20;-- 刪除默認值約束ALTER table tb1 alter haha drop default;-- 設置外鍵約束 必選部分  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;-- 刪除外鍵約束,由于常見外鍵時會生成索引,所以刪除外鍵后,需要刪索引。alter table tb1 drop foreign key waijianming;alter table tb1 drop INDEX waijianming;

SHOW COLUMNS FROM TB1;

4 數據庫的三大范式
   
1、第一范式(1NF):數據表中的每一列(字段),必須是不可拆分的最小單元。也就是確保每一列的原子性。
例如: userInfo:'山東省煙臺市 13181621008'
userads:'山東省煙臺市' userTel:'13181621008'

2、第二范式(2NF):滿足1NF后,要求:表中的所有列,都必須依賴于主鍵,而不能有任何一列與主鍵沒有關系。 也就是說,一個表只描述一件事情。

例如: 訂單表,只能描述訂單相關的信息,所以所有的字段都必須與訂單ID相關;
產品表,只能描述產品相關的信息,所以所有的字段都必須與產品ID相關;
因此: 不能在同一張表中同事出現訂單信息與產品信息。

3、第三范式(3NF):表中的每一列都要與主鍵直接相關,而不是間接相關。(表中的每一列,只能依賴于主鍵)。
例如:訂單表中,需要有客戶相關信息,在分理處客戶表之后。訂單表中,只需要有一個用戶ID即可。而不能有其他的客戶信息。因為,其他的用戶信息是直接關聯于用戶ID,而不是關聯于訂單ID。


【第二范式與第三范式的本質區別】
在于沒有分出兩張表,第二范式是說一張表中包含了多種不同實體的屬性,那么必須要分成多張表。
第三范式是要求,已經分好了多張表的化,那么,一張表中只能有另一張表中的ID(主鍵),而不能有其他的任何信息(其他的任何信息,一律用主鍵在另一表查詢)

學習基礎mysql語法

學習基礎mysql語法

學習基礎mysql語法

學習時候的筆記,可能會有一些錯誤的地方,歡迎各位的批評指點。

反思,復盤,每天收獲一點---------------------期待更好的自己

以上就是學習基礎mysql語法的詳細內容,更多請關注php中文網其它相關文章!


學習教程快速掌握從入門到精通的SQL知識。




主站蜘蛛池模板: 视频二区欧美 | 午夜精品久久久久久久99热下载 | 日韩欧美视频 | 中文婷婷 | 欧美综合区自拍亚洲综合 | 亚洲成a人片在线观看 欧美 | 亚洲日本高清 | 色综合日韩 | 欧美亚洲国产激情一区二区 | 日韩一级欧美一级在线观看 | 欧美一级高清在线观看 | 亚洲国产成人久久综合碰 | 中文字幕在线观看第一页 | 欧洲亚洲精品 | 青娱乐手机在线 | 亚洲免费在线看 | 天天躁 | 日本三级理论片 | 婷婷天堂| 特片网在线观看 | 午夜男人网站 | 日韩污视频 | 日本一区二区三区免费观看 | 色日韩在线 | 午夜影视免费完整高清在线观看网站 | 亚洲视频色 | 欧洲性xxxx免费视频下载软件 | 欧美综合在线视频 | 亚洲综合丁香婷婷六月香 | 日本视频免费 | 欧美一级一级做性视频 | 天天色一色 | 青娱乐久久 | 亚洲最新网站 | 日本高清一区二区三区不卡免费 | 日日噜噜噜夜夜爽爽狠狠 | 日韩精品一区二区三区中文 | 天天干天天射天天 | 啪啪网站免费观看 | 天美传媒精品一区 | 三级中文有码中文字幕 |