小編給大家分享一下怎么設計數據庫及授予權限,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
在數據庫中,我們可以做許許多多的事情,比如給用戶(hù)授予權限,設計數據庫等等。
權限及設計數據庫
使用SQLyog 創(chuàng )建用戶(hù),并授予權限演示
基本命令
/* 用戶(hù)和權限管理 */ ------------------ 用戶(hù)信息表:.user -- 刷新權限 FLUSH PRIVILEGES -- 增加用戶(hù) CREATE USER kuangshen IDENTIFIED BY '123456' CREATE USER 用戶(hù)名 IDENTIFIED BY [PASSWORD] 密碼(字符串) - 必須擁有mysql數據庫的全局CREATE USER權限,或擁有INSERT權限。 - 只能創(chuàng )建用戶(hù),不能賦予權限。 - 用戶(hù)名,注意引號:如 'user_name'@'192.168.1.1' - 密碼也需引號,純數字密碼也要加引號 - 要在純文本中指定密碼,需忽略PASSWORD關(guān)鍵詞。要把密碼指定為由PASSWORD()函數返回的混編值,需包含關(guān)鍵字PASSWORD -- 重命名用戶(hù) RENAME USER kuangshen TO kuangshen2 RENAME USER old_user TO new_user -- 設置密碼 SET PASSWORD = PASSWORD('密碼') -- 為當前用戶(hù)設置密碼 SET PASSWORD FOR 用戶(hù)名 = PASSWORD('密碼') -- 為指定用戶(hù)設置密碼 -- 刪除用戶(hù) DROP USER kuangshen2 DROP USER 用戶(hù)名 -- 分配權限/添加用戶(hù) GRANT 權限列表 ON 表名 TO 用戶(hù)名 [IDENTIFIED BY [PASSWORD] 'password'] - all privileges 表示所有權限 - *.* 表示所有庫的所有表 - 庫名.表名 表示某庫下面的某表 -- 查看權限 SHOW GRANTS FOR root@localhost; SHOW GRANTS FOR 用戶(hù)名 -- 查看當前用戶(hù)權限 SHOW GRANTS; 或 SHOW GRANTS FOR CURRENT_USER; 或 SHOW GRANTS FOR CURRENT_USER(); -- 撤消權限 REVOKE 權限列表 ON 表名 FROM 用戶(hù)名 REVOKE ALL PRIVILEGES, GRANT OPTION FROM 用戶(hù)名 -- 撤銷(xiāo)所有權限
權限解釋
-- 權限列表 ALL [PRIVILEGES] -- 設置除GRANT OPTION之外的所有簡(jiǎn)單權限 ALTER -- 允許使用ALTER TABLE ALTER ROUTINE -- 更改或取消已存儲的子程序 CREATE -- 允許使用CREATE TABLE CREATE ROUTINE -- 創(chuàng )建已存儲的子程序 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 -- 允許用戶(hù)運行已存儲的子程序 FILE -- 允許使用SELECT...INTO OUTFILE和LOAD DATA INFILE INDEX -- 允許使用CREATE INDEX和DROP INDEX INSERT -- 允許使用INSERT LOCK TABLES -- 允許對您擁有SELECT權限的表使用LOCK TABLES PROCESS -- 允許使用SHOW FULL PROCESSLIST REFERENCES -- 未被實(shí)施 RELOAD -- 允許使用FLUSH REPLICATION CLIENT -- 允許用戶(hù)詢(xún)問(wèn)從屬或主服務(wù)器的地址 REPLICATION SLAVE -- 用于復制型從屬服務(wù)器(從主服務(wù)器中讀取二進(jìn)制日志事件) SELECT -- 允許使用SELECT SHOW DATABASES -- 顯示所有數據庫 SHOW VIEW -- 允許使用SHOW CREATE VIEW SHUTDOWN -- 允許使用mysqladmin shutdown SUPER -- 允許使用CHANGE MASTER, KILL, PURGE MASTER LOGS和SET GLOBAL語(yǔ)句,mysqladmin debug命令;允許您連接(一次),即使已達到max_connections。 UPDATE -- 允許使用UPDATE USAGE -- “無(wú)權限”的同義詞 GRANT OPTION -- 允許授予權限 /* 表維護 */ -- 分析和存儲表的關(guān)鍵字分布 ANALYZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE 表名 ... -- 檢查一個(gè)或多個(gè)表是否有錯誤 CHECK TABLE tbl_name [, tbl_name] ... [option] ... option = {QUICK | FAST | MEDIUM | EXTENDED | CHANGED} -- 整理數據文件的碎片 OPTIMIZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ...
數據庫備份必要性
保證重要數據不丟失
數據轉移
MySQL數據庫備份方法
mysqldump備份工具
數據庫管理工具,如SQLyog
直接拷貝數據庫文件和相關(guān)配置文件
mysqldump客戶(hù)端
作用 :
轉儲數據庫
搜集數據庫進(jìn)行備份
將數據轉移到另一個(gè)SQL服務(wù)器,不一定是MySQL服務(wù)器
-- 導出 1. 導出一張表 -- mysqldump -uroot -p123456 school student >D:/a.sql mysqldump -u用戶(hù)名 -p密碼 庫名 表名 > 文件名(D:/a.sql) 2. 導出多張表 -- mysqldump -uroot -p123456 school student result >D:/a.sql mysqldump -u用戶(hù)名 -p密碼 庫名 表1 表2 表3 > 文件名(D:/a.sql) 3. 導出所有表 -- mysqldump -uroot -p123456 school >D:/a.sql mysqldump -u用戶(hù)名 -p密碼 庫名 > 文件名(D:/a.sql) 4. 導出一個(gè)庫 -- mysqldump -uroot -p123456 -B school >D:/a.sql mysqldump -u用戶(hù)名 -p密碼 -B 庫名 > 文件名(D:/a.sql) 可以-w攜帶備份條件 -- 導入 1. 在登錄mysql的情況下:-- source D:/a.sql source 備份文件 2. 在不登錄的情況下 mysql -u用戶(hù)名 -p密碼 庫名 < 備份文件
當數據庫比較復雜時(shí)我們需要設計數據庫
糟糕的數據庫設計 :
數據冗余,存儲空間浪費
數據更新和插入的異常
程序性能差
良好的數據庫設計 :
節省數據的存儲空間
能夠保證數據的完整性
方便進(jìn)行數據庫應用系統的開(kāi)發(fā)
軟件項目開(kāi)發(fā)周期中數據庫設計 :
需求分析階段: 分析客戶(hù)的業(yè)務(wù)和數據處理需求
概要設計階段:設計數據庫的E-R模型圖 , 確認需求信息的正確和完整.
設計數據庫步驟
收集信息
與該系統有關(guān)人員進(jìn)行交流 , 座談 , 充分了解用戶(hù)需求 , 理解數據庫需要完成的任務(wù).
標識實(shí)體[Entity]
標識數據庫要管理的關(guān)鍵對象或實(shí)體,實(shí)體一般是名詞
標識每個(gè)實(shí)體需要存儲的詳細信息[Attribute]
標識實(shí)體之間的關(guān)系[Relationship]
問(wèn)題 : 為什么需要數據規范化?
不合規范的表設計會(huì )導致的問(wèn)題:
信息重復
更新異常
插入異常
無(wú)法正確表示信息
刪除異常
丟失有效信息
三大范式
第一范式 (1st NF)
第一范式的目標是確保每列的原子性,如果每列都是不可再分的最小數據單元,則滿(mǎn)足第一范式
第二范式(2nd NF)
第二范式(2NF)是在第一范式(1NF)的基礎上建立起來(lái)的,即滿(mǎn)足第二范式(2NF)必須先滿(mǎn)足第一范式(1NF)。
第二范式要求每個(gè)表只描述一件事情
第三范式(3rd NF)
如果一個(gè)關(guān)系滿(mǎn)足第二范式,并且除了主鍵以外的其他列都不傳遞依賴(lài)于主鍵列,則滿(mǎn)足第三范式.
第三范式需要確保數據表中的每一列數據都和主鍵直接相關(guān),而不能間接相關(guān)。
規范化和性能的關(guān)系
為滿(mǎn)足某種商業(yè)目標 , 數據庫性能比規范化數據庫更重要
在數據規范化的同時(shí) , 要綜合考慮數據庫的性能
通過(guò)在給定的表中添加額外的字段,以大量減少需要從中搜索信息所需的時(shí)間
通過(guò)在給定的表中插入計算列,以方便查詢(xún)
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站