Mysql-----權限和數據庫設計

用戶和權限管理

/* 用戶和權限管理 */ ------------------
用戶信息表:mysql.user

-- 刷新權限
FLUSH PRIVILEGES

-- 增加用戶
CREATE USER 用戶名 IDENTIFIED BY [PASSWORD] 密碼(字符串)
    - 必須擁有mysql數據庫的全局CREATE USER權限,或擁有INSERT權限。
    - 只能創建用戶,不能賦予權限。
    - 用戶名,注意引號:如 'user_name'@'192.168.1.1'
    - 密碼也需引號,純數字密碼也要加引號
    - 要在純文本中指定密碼,需忽略PASSWORD關鍵詞。要把密碼指定爲由PASSWORD()函數返回的混編值,需包含關鍵字PASSWORD

-- 重命名用戶
RENAME USER old_user TO new_user

-- 設置密碼
SET PASSWORD = PASSWORD('密碼')    -- 爲當前用戶設置密碼
SET PASSWORD FOR 用戶名 = PASSWORD('密碼')    -- 爲指定用戶設置密碼

-- 刪除用戶
DROP USER 用戶名

-- 分配權限/添加用戶
GRANT 權限列表 ON 表名 TO 用戶名 [IDENTIFIED BY [PASSWORD] 'password']
    - all privileges 表示所有權限
    - *.* 表示所有庫的所有表
    - 庫名.表名 表示某庫下面的某表

-- 查看權限
SHOW GRANTS FOR 用戶名
    -- 查看當前用戶權限
    SHOW GRANTS; 或 SHOW GRANTS FOR CURRENT_USER; 或 SHOW GRANTS FOR CURRENT_USER();

-- 撤消權限
REVOKE 權限列表 ON 表名 FROM 用戶名
REVOKE ALL PRIVILEGES, GRANT OPTION FROM 用戶名    -- 撤銷所有權限

-- 權限層級
-- 要使用GRANT或REVOKE,您必須擁有GRANT OPTION權限,並且您必須用於您正在授予或撤銷的權限。
全局層級:全局權限適用於一個給定服務器中的所有數據庫,mysql.user
    GRANT ALL ON *.*和 REVOKE ALL ON *.*只授予和撤銷全局權限。
數據庫層級:數據庫權限適用於一個給定數據庫中的所有目標,mysql.db, mysql.host
    GRANT ALL ON db_name.*和REVOKE ALL ON db_name.*只授予和撤銷數據庫權限。
表層級:表權限適用於一個給定表中的所有列,mysql.talbes_priv
    GRANT ALL ON db_name.tbl_name和REVOKE ALL ON db_name.tbl_name只授予和撤銷表權限。
列層級:列權限適用於一個給定表中的單一列,mysql.columns_priv
    當使用REVOKE時,您必須指定與被授權列相同的列。


-- 權限列表
ALL [PRIVILEGES]    -- 設置除GRANT OPTION之外的所有簡單權限
ALTER    -- 允許使用ALTER TABLE
ALTER ROUTINE    -- 更改或取消已存儲的子程序
CREATE    -- 允許使用CREATE TABLE
CREATE ROUTINE    -- 創建已存儲的子程序
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        -- 允許用戶運行已存儲的子程序
FILE    -- 允許使用SELECT...INTO OUTFILE和LOAD DATA INFILE
INDEX     -- 允許使用CREATE INDEX和DROP INDEX
INSERT    -- 允許使用INSERT
LOCK TABLES        -- 允許對您擁有SELECT權限的表使用LOCK TABLES
PROCESS     -- 允許使用SHOW FULL PROCESSLIST
REFERENCES    -- 未被實施
RELOAD    -- 允許使用FLUSH
REPLICATION CLIENT    -- 允許用戶詢問從屬服務器或主服務器的地址
REPLICATION SLAVE    -- 用於複製型從屬服務器(從主服務器中讀取二進制日誌事件)
SELECT    -- 允許使用SELECT
SHOW DATABASES    -- 顯示所有數據庫
SHOW VIEW    -- 允許使用SHOW CREATE VIEW
SHUTDOWN    -- 允許使用mysqladmin shutdown
SUPER    -- 允許使用CHANGE MASTER, KILL, PURGE MASTER LOGS和SET GLOBAL語句,mysqladmin debug命令;允許您連接(一次),即使已達到max_connections。
UPDATE    -- 允許使用UPDATE
USAGE    -- “無權限”的同義詞
GRANT OPTION    -- 允許授予權限


/* 表維護 */


-- 分析和存儲表的關鍵字分佈
ANALYZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE 表名 ...
-- 檢查一個或多個表是否有錯誤
CHECK TABLE tbl_name [, tbl_name] ... [option] ...
option = {QUICK | FAST | MEDIUM | EXTENDED | CHANGED}
-- 整理數據文件的碎片
OPTIMIZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ...

規範化數據庫設計

爲什麼需要設計數據庫 ?

答:當數據庫比較複雜時我們需要設計數據庫

糟糕的數據庫設計 :

數據冗餘,存儲空間浪費
數據更新和插入的異常
程序性能差
良好的數據庫設計 :

節省數據的存儲空間
能夠保證數據的完整性
方便進行數據庫應用系統的開發
軟件項目開發週期中數據庫設計 :

需求分析階段: 分析客戶的業務和數據處理需求
概要設計階段:設計數據庫的E-R模型圖 , 確認需求信息的正確和完整.

設計數據庫步驟

收集信息
與該系統有關人員進行交流 , 座談 , 充分了解用戶需求 , 理解數據庫需要完成的任務.
標識實體[Entity]
標識數據庫要管理的關鍵對象或實體,實體一般是名詞
標識每個實體需要存儲的詳細信息[Attribute]
標識實體之間的關係[Relationship]

繪製E-R圖和數據庫模型圖

E-R圖即數據庫設計的圖形化表達方式 , 也稱爲實體-關係圖
在這裏插入圖片描述
關係模式 : 用二維表的形式表示實體和實體間聯繫的數據模型即關係模式R(U)

繪製數據庫模型圖的步驟 :

新建數據庫模型圖
添加實體
添加數據列及相應的屬性
添加實體之間的映射關係

三大範式

問題 : 爲什麼需要數據規範化?

不合規範的表設計
信息重複
更新異常
插入異常
無法正確表示信息
刪除異常
丟失有效信息

第一範式 (1st NF)

第一範式的目標是確保每列的原子性,如果每列都是不可再分的最小數據單元,則滿足第一範式

第二範式(2nd NF)

第二範式要求每個表只描述一件事情

第三範式(3rd NF)

如果一個關係滿足第二範式,並且除了主鍵以外的其他列都不傳遞依賴於主鍵列,則滿足第三範式.

規範化和性能的關係

爲滿足某種商業目標 , 數據庫性能比規範化數據庫更重要

在數據規範化的同時 , 要綜合考慮數據庫的性能

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

通過在給定的表中插入計算列,以方便查詢

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章