學習mysql語法--基礎篇(一)

来源:http://www.cnblogs.com/zhuanzhibukaixin/archive/2017/06/22/7067500.html
-Advertisement-
Play Games

前 言 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(主鍵),而不能有其他的任何信息(其他的任何信息,一律用主鍵在另一表查詢)
         

 

 

 

 

 

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

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

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 文章相對來說比較複雜,特別是查找版本ID對應的步驟,這裡推薦使用另一種方案,操作起來更簡單。 本文介紹如何使用Workflow及Fiddler下載IOS舊版本APP應用。 ...
  • 關於 iOS 與 OS X 端字體的優化(橫豎屏會出現字體加粗不一致等) iOS 瀏覽器橫屏時會重置字體大小,設置 text-size-adjust 為 none 可以解決 iOS 上的問題,但桌面版 Safari 的字體縮放功能會失效,因此最佳方案是將 text-size-adjust 為 10... ...
  • 1。手機充電充一整晚的 capacity 和 充電充到 100% 立刻停止的 capacity 是不一樣的, 為什麼不一樣呢? 手機充電到 100% 立刻停止, 因為化學特性尚未穩定, 電池電壓 會慢慢 往下掉, 未達到 額定的 capacity, 若是充一整晚呢? 在沒有 power path 的 ...
  • 碰見一個很奇葩的問題, 某些手機在設置了不知什麼後, 某些 APP 死活 HTTPS 請求失敗, 例如以 UMeng 統計HTTP 請求失敗為例, Log如下: UMLOG: (Error Applog) Error Domain=NSURLErrorDomain Code=-1202 "此伺服器的 ...
  • Volley源碼分析 雖然在2017年,volley已經是一個逐漸被淘汰的框架,但其代碼短小精悍,網路架構設計巧妙,還是有很多值得學習的地方。 第一篇文章,分析了請求隊列的代碼,請求隊列也是我們使用Volley的關鍵一步。 第二篇文章會分析Dispatcher RequestQueue 創建Requ ...
  • Kotlin做為一門編程語言,已經出現好幾年了,但此前在國內並不聞名。自從5月份谷歌宣佈它成為Android的官方開發語言之後,Kotlin猛然竄紅了,雖說短期內Kotlin無法取代Java,但對於一門新技術,我們還是有必要好好學習。 谷歌號稱從Android Studio 3.0開始完全支持Kot ...
  • 一,代碼: - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typically from a nib. NSLog(@" 產生隨機字元串 %@",[self g ...
  • requests 模塊 模塊的由來: 瀏覽器可以瀏覽網站, 是由於瀏覽器發送了requests , 各種請求.打開一個網站可能有幾十到幾百個請求. 從而伺服器端會反饋各種因應不同請求生成的數據. 我們瀏覽器再decode這些數據來顯示在屏幕上. requests, 就是Python一種用來偽裝成模擬... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...