欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL之權(quán)限以及設(shè)計(jì)數(shù)據(jù)庫(kù)案例講解

 更新時(shí)間:2021年08月09日 09:00:44   作者:狂神說(shuō)  
這篇文章主要介紹了MySQL之權(quán)限以及設(shè)計(jì)數(shù)據(jù)庫(kù)案例講解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

權(quán)限及設(shè)計(jì)數(shù)據(jù)庫(kù)

用戶管理

使用SQLyog 創(chuàng)建用戶,并授予權(quán)限演示

基本命令

/* 用戶和權(quán)限管理 */ ------------------
用戶信息表:mysql.user
 
-- 刷新權(quán)限
FLUSH PRIVILEGES
 
-- 增加用戶  CREATE USER kuangshen IDENTIFIED BY '123456'
CREATE USER 用戶名 IDENTIFIED BY [PASSWORD] 密碼(字符串)
    - 必須擁有mysql數(shù)據(jù)庫(kù)的全局CREATE USER權(quán)限,或擁有INSERT權(quán)限。
    - 只能創(chuàng)建用戶,不能賦予權(quán)限。
    - 用戶名,注意引號(hào):如 'user_name'@'192.168.1.1'
    - 密碼也需引號(hào),純數(shù)字密碼也要加引號(hào)
    - 要在純文本中指定密碼,需忽略PASSWORD關(guān)鍵詞。要把密碼指定為由PASSWORD()函數(shù)返回的混編值,需包含關(guān)鍵字PASSWORD
 
-- 重命名用戶  RENAME USER kuangshen TO kuangshen2
RENAME USER old_user TO new_user
 
-- 設(shè)置密碼
SET PASSWORD = PASSWORD('密碼')    -- 為當(dāng)前用戶設(shè)置密碼
SET PASSWORD FOR 用戶名 = PASSWORD('密碼')    -- 為指定用戶設(shè)置密碼
 
-- 刪除用戶  DROP USER kuangshen2
DROP USER 用戶名
 
-- 分配權(quán)限/添加用戶
GRANT 權(quán)限列表 ON 表名 TO 用戶名 [IDENTIFIED BY [PASSWORD] 'password']
    - all privileges 表示所有權(quán)限
    - *.* 表示所有庫(kù)的所有表
    - 庫(kù)名.表名 表示某庫(kù)下面的某表
 
-- 查看權(quán)限   SHOW GRANTS FOR root@localhost;
SHOW GRANTS FOR 用戶名
    -- 查看當(dāng)前用戶權(quán)限
    SHOW GRANTS; 或 SHOW GRANTS FOR CURRENT_USER; 或 SHOW GRANTS FOR CURRENT_USER();
 
-- 撤消權(quán)限
REVOKE 權(quán)限列表 ON 表名 FROM 用戶名
REVOKE ALL PRIVILEGES, GRANT OPTION FROM 用戶名    -- 撤銷所有權(quán)限

權(quán)限解釋

-- 權(quán)限列表
ALL [PRIVILEGES]    -- 設(shè)置除GRANT OPTION之外的所有簡(jiǎn)單權(quán)限
ALTER    -- 允許使用ALTER TABLE
ALTER ROUTINE    -- 更改或取消已存儲(chǔ)的子程序
CREATE    -- 允許使用CREATE TABLE
CREATE ROUTINE    -- 創(chuàng)建已存儲(chǔ)的子程序
CREATE TEMPORARY TABLES        -- 允許使用CREATE TEMPORARY TABLE
CREATE USER        -- 允許使用CREATE USER, DROP USER, RENAME USER和REVOKE ALL PRIVILEGES。
CREATE VIEW        -- 允許使用CREATE VIEW
DELETE    -- 允許使用DELETE
DROP    -- 允許使用DROP TABLE
EXECUTE        -- 允許用戶運(yùn)行已存儲(chǔ)的子程序
FILE    -- 允許使用SELECT...INTO OUTFILE和LOAD DATA INFILE
INDEX     -- 允許使用CREATE INDEX和DROP INDEX
INSERT    -- 允許使用INSERT
LOCK TABLES        -- 允許對(duì)您擁有SELECT權(quán)限的表使用LOCK TABLES
PROCESS     -- 允許使用SHOW FULL PROCESSLIST
REFERENCES    -- 未被實(shí)施
RELOAD    -- 允許使用FLUSH
REPLICATION CLIENT    -- 允許用戶詢問(wèn)從屬服務(wù)器或主服務(wù)器的地址
REPLICATION SLAVE    -- 用于復(fù)制型從屬服務(wù)器(從主服務(wù)器中讀取二進(jìn)制日志事件)
SELECT    -- 允許使用SELECT
SHOW DATABASES    -- 顯示所有數(shù)據(jù)庫(kù)
SHOW VIEW    -- 允許使用SHOW CREATE VIEW
SHUTDOWN    -- 允許使用mysqladmin shutdown
SUPER    -- 允許使用CHANGE MASTER, KILL, PURGE MASTER LOGS和SET GLOBAL語(yǔ)句,mysqladmin debug命令;允許您連接(一次),即使已達(dá)到max_connections。
UPDATE    -- 允許使用UPDATE
USAGE    -- “無(wú)權(quán)限”的同義詞
GRANT OPTION    -- 允許授予權(quán)限
 
 
/* 表維護(hù) */
 
-- 分析和存儲(chǔ)表的關(guān)鍵字分布
ANALYZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE 表名 ...
-- 檢查一個(gè)或多個(gè)表是否有錯(cuò)誤
CHECK TABLE tbl_name [, tbl_name] ... [option] ...
option = {QUICK | FAST | MEDIUM | EXTENDED | CHANGED}
-- 整理數(shù)據(jù)文件的碎片
OPTIMIZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ...

MySQL備份

數(shù)據(jù)庫(kù)備份必要性

  • 保證重要數(shù)據(jù)不丟失
  • 數(shù)據(jù)轉(zhuǎn)移

MySQL數(shù)據(jù)庫(kù)備份方法

  • mysqldump備份工具
  • 數(shù)據(jù)庫(kù)管理工具,如SQLyog
  • 直接拷貝數(shù)據(jù)庫(kù)文件和相關(guān)配置文件

mysqldump客戶端

作用 :

  • 轉(zhuǎn)儲(chǔ)數(shù)據(jù)庫(kù)
  • 搜集數(shù)據(jù)庫(kù)進(jìn)行備份
  • 將數(shù)據(jù)轉(zhuǎn)移到另一個(gè)SQL服務(wù)器,不一定是MySQL服務(wù)器

-- 導(dǎo)出
1. 導(dǎo)出一張表 -- mysqldump -uroot -p123456 school student >D:/a.sql
  mysqldump -u用戶名 -p密碼 庫(kù)名 表名 > 文件名(D:/a.sql)
2. 導(dǎo)出多張表 -- mysqldump -uroot -p123456 school student result >D:/a.sql
  mysqldump -u用戶名 -p密碼 庫(kù)名 表1 表2 表3 > 文件名(D:/a.sql)
3. 導(dǎo)出所有表 -- mysqldump -uroot -p123456 school >D:/a.sql
  mysqldump -u用戶名 -p密碼 庫(kù)名 > 文件名(D:/a.sql)
4. 導(dǎo)出一個(gè)庫(kù) -- mysqldump -uroot -p123456 -B school >D:/a.sql
  mysqldump -u用戶名 -p密碼 -B 庫(kù)名 > 文件名(D:/a.sql)
 
可以-w攜帶備份條件
 
-- 導(dǎo)入
1. 在登錄mysql的情況下:-- source D:/a.sql
  source  備份文件
2. 在不登錄的情況下
  mysql -u用戶名 -p密碼 庫(kù)名 < 備份文件

規(guī)范化數(shù)據(jù)庫(kù)設(shè)計(jì)

為什么需要數(shù)據(jù)庫(kù)設(shè)計(jì)

當(dāng)數(shù)據(jù)庫(kù)比較復(fù)雜時(shí)我們需要設(shè)計(jì)數(shù)據(jù)庫(kù)

糟糕的數(shù)據(jù)庫(kù)設(shè)計(jì) :

  • 數(shù)據(jù)冗余,存儲(chǔ)空間浪費(fèi)
  • 數(shù)據(jù)更新和插入的異常
  • 程序性能差

良好的數(shù)據(jù)庫(kù)設(shè)計(jì) :

  • 節(jié)省數(shù)據(jù)的存儲(chǔ)空間
  • 能夠保證數(shù)據(jù)的完整性
  • 方便進(jìn)行數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)的開(kāi)發(fā)

軟件項(xiàng)目開(kāi)發(fā)周期中數(shù)據(jù)庫(kù)設(shè)計(jì) :

  • 需求分析階段: 分析客戶的業(yè)務(wù)和數(shù)據(jù)處理需求
  • 概要設(shè)計(jì)階段:設(shè)計(jì)數(shù)據(jù)庫(kù)的E-R模型圖 , 確認(rèn)需求信息的正確和完整.

設(shè)計(jì)數(shù)據(jù)庫(kù)步驟

  • 收集信息
  • 與該系統(tǒng)有關(guān)人員進(jìn)行交流 , 座談 , 充分了解用戶需求 , 理解數(shù)據(jù)庫(kù)需要完成的任務(wù).
  • 標(biāo)識(shí)實(shí)體[Entity]
  • 標(biāo)識(shí)數(shù)據(jù)庫(kù)要管理的關(guān)鍵對(duì)象或?qū)嶓w,實(shí)體一般是名詞
  • 標(biāo)識(shí)每個(gè)實(shí)體需要存儲(chǔ)的詳細(xì)信息[Attribute]
  • 標(biāo)識(shí)實(shí)體之間的關(guān)系[Relationship]

三大范式

問(wèn)題 : 為什么需要數(shù)據(jù)規(guī)范化?

不合規(guī)范的表設(shè)計(jì)會(huì)導(dǎo)致的問(wèn)題:

  • 信息重復(fù)
  • 更新異常
  • 插入異常
    • 無(wú)法正確表示信息
  • 刪除異常
    • 丟失有效信息

三大范式

第一范式 (1st NF)

第一范式的目標(biāo)是確保每列的原子性,如果每列都是不可再分的最小數(shù)據(jù)單元,則滿足第一范式

第二范式(2nd NF)

第二范式(2NF)是在第一范式(1NF)的基礎(chǔ)上建立起來(lái)的,即滿足第二范式(2NF)必須先滿足第一范式(1NF)。

第二范式要求每個(gè)表只描述一件事情

第三范式(3rd NF)

如果一個(gè)關(guān)系滿足第二范式,并且除了主鍵以外的其他列都不傳遞依賴于主鍵列,則滿足第三范式.

第三范式需要確保數(shù)據(jù)表中的每一列數(shù)據(jù)都和主鍵直接相關(guān),而不能間接相關(guān)。

規(guī)范化和性能的關(guān)系

為滿足某種商業(yè)目標(biāo) , 數(shù)據(jù)庫(kù)性能比規(guī)范化數(shù)據(jù)庫(kù)更重要

在數(shù)據(jù)規(guī)范化的同時(shí) , 要綜合考慮數(shù)據(jù)庫(kù)的性能

通過(guò)在給定的表中添加額外的字段,以大量減少需要從中搜索信息所需的時(shí)間

通過(guò)在給定的表中插入計(jì)算列,以方便查詢

到此這篇關(guān)于MySQL之權(quán)限以及設(shè)計(jì)數(shù)據(jù)庫(kù)案例講解的文章就介紹到這了,更多相關(guān)MySQL之權(quán)限以及設(shè)計(jì)數(shù)據(jù)庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL配置文件my.cnf參數(shù)優(yōu)化和中文詳解

    MySQL配置文件my.cnf參數(shù)優(yōu)化和中文詳解

    這篇文章主要介紹了MySQL配置文件my.cnf參數(shù)優(yōu)化和中文詳解,非常詳細(xì)的用中文注釋了各個(gè)參數(shù)的作用以及建議值,需要的朋友可以參考下
    2014-03-03
  • mysql存儲(chǔ)過(guò)程用法實(shí)例分析

    mysql存儲(chǔ)過(guò)程用法實(shí)例分析

    這篇文章主要介紹了mysql存儲(chǔ)過(guò)程用法,結(jié)合實(shí)例形式簡(jiǎn)單分析了mysql存儲(chǔ)過(guò)程的概念、功能、定義、執(zhí)行、調(diào)用等相關(guān)操作技巧,需要的朋友可以參考下
    2018-03-03
  • MySQL 存儲(chǔ)過(guò)程傳參數(shù)實(shí)現(xiàn)where id in(1,2,3,...)示例

    MySQL 存儲(chǔ)過(guò)程傳參數(shù)實(shí)現(xiàn)where id in(1,2,3,...)示例

    一個(gè)MySQL 存儲(chǔ)過(guò)程傳參數(shù)的問(wèn)題想實(shí)現(xiàn)例如篩選條件為:where id in(1,2,3,...),下面有個(gè)不錯(cuò)的示例,感興趣的朋友可以參考下
    2013-10-10
  • mysql實(shí)現(xiàn)事務(wù)的提交與回滾的實(shí)例詳解

    mysql實(shí)現(xiàn)事務(wù)的提交與回滾的實(shí)例詳解

    在本篇文章中我們給大家分享一篇關(guān)于mysql實(shí)現(xiàn)事務(wù)的提交與回滾的實(shí)例內(nèi)容,有需要的朋友們可以參考學(xué)習(xí)下。
    2020-01-01
  • MySQL之join查詢優(yōu)化方式

    MySQL之join查詢優(yōu)化方式

    這篇文章主要介紹了MySQL之join查詢優(yōu)化方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • mysql 提示INNODB錯(cuò)誤的解決方法

    mysql 提示INNODB錯(cuò)誤的解決方法

    解決The‘InnoDB’feature is disabled; you need MySQL built with ‘InnoDB’ to have it
    2011-09-09
  • 解決MySql版本問(wèn)題sql_mode=only_full_group_by

    解決MySql版本問(wèn)題sql_mode=only_full_group_by

    這篇文章主要介紹了解決MySql版本問(wèn)題sql_mode=only_full_group_by,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • MySQL不就是多表查詢嗎

    MySQL不就是多表查詢嗎

    這篇文章主要介紹了MySQL多表查詢相關(guān)知識(shí),今天我們學(xué)習(xí)要對(duì)多張表進(jìn)行相關(guān)操作,相比較于單一的表來(lái)說(shuō),多張表操作相對(duì)復(fù)雜一些,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • mysql的虛擬表(DUAL)的介紹及使用場(chǎng)景

    mysql的虛擬表(DUAL)的介紹及使用場(chǎng)景

    本文主要介紹了mysql的虛擬表(DUAL)的介紹及使用場(chǎng)景,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-04-04
  • mysql 5.7.17 安裝配置方法圖文教程

    mysql 5.7.17 安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了mysql 5.7.17 安裝配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-06-06

最新評(píng)論