mysql學習【第6篇】:許可權和資料庫設計

来源:https://www.cnblogs.com/hellokuangshen/archive/2019/01/15/10272298.html
-Advertisement-
Play Games

狂神聲明 : 文章均為自己的學習筆記 , 轉載一定註明出處 ; 編輯不易 , 防君子不防小人~共勉 ! mysql學習【第6篇】:許可權和資料庫設計 用戶和許可權管理 規範化資料庫設計 為什麼需要設計資料庫 ? 答:當資料庫比較複雜時我們需要設計資料庫 糟糕的資料庫設計 : 數據冗餘,存儲空間浪費 數據 ...


狂神聲明 : 文章均為自己的學習筆記 , 轉載一定註明出處 ; 編輯不易 , 防君子不防小人~共勉 ! 

mysql學習【第6篇】:許可權和資料庫設計

用戶和許可權管理

/* 用戶和許可權管理 */ ------------------
用戶信息表: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)

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

 

規範化和性能的關係

為滿足某種商業目標 , 資料庫性能比規範化資料庫更重要

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

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

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

 


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

-Advertisement-
Play Games
更多相關文章
  • 本文收錄在容器技術學習系列文章總目錄 1、限制容器的資源 預設情況下,容器沒有資源限制,可以使用主機內核調度程式允許的儘可能多的給定資源。Docker提供了控制容器可以使用多少記憶體或CPU的方法,設置docker run命令的運行時配置標誌。本篇提供有關何時應設置此類限制的詳細信息以及設置這些限制的 ...
  • 系統組成 版本XX.XX.XX XX主版本,XX副版本(奇數為測試版,偶數為穩定版),修訂版本號 , 表示修改的次數(debug) linux主流分支 硬碟分區 /dev/hda5 硬體設備所在分區 hd 表示IDE設備,sd表示SCSI設備 硬碟的順序號,以字母abcd...... 分區的順序號1 ...
  • 在tomcat下部署項目,第一次訪問成功。但是發現有一個頁面沒有成功載入,發現是部署時少了一些東西。也不想去找出具體少了什麼,直接把原來的項目移除,重新載入項目。重啟tomcat,這時驚喜來了。 重啟完tomcat,用瀏覽器訪問https://XXXXXXX:8443。結果是訪問請求被拒絕。 先看防 ...
  • 查看系統中shell的類型 cat /etc/shells 切換用戶使用的shell chsh s /bin/bash username sudo usermod s ...
  • 一、增加數據 普通的插入 查詢出來的數據可以作為數據添加到列表中 二、刪除數據 刪除部分數據 刪除表中全部的數據1,表的結構不變,但不刪除表的自增主鍵 刪除表中全部的數據2,表的結構不變。刪除表的自增主鍵 還有一種刪除表中全部內容的方法,它不像delete那樣還要逐條看看再刪,而是直接清空掉,可以聯 ...
  • SELECT a.tb_name 表空間名稱, c.contents 類型, c.extent_management 區管理, b.total / 1024 / 1024 表空間大小m, (b.total - a.free_sp) / 1024 / 1024 已使用m, a.free_sp / 10 ...
  • 如果你關註大數據科技動向,你對 NoSQL 一定不陌生,NoSQL 是一個分散式資料庫。在過去時間,數據存儲一直關係型資料庫天下,有著良好的控制併發操作、事務功能。雖然RDBMS很優秀,但是隨著時間的推移就出現了兩個關係資料庫解決不了的問題:快速增長的數據規模和日漸複雜的數據模型。結果,我們看到了 ...
  • SQL Server獲得排名或排序的函數有如下幾種: 1、Rank():在結果集中每一條記錄所在的排名位置,但排名可能不連續,例如:若同一組內有兩個第一名,則該組內下一個名次直接跳至第三名 select *,Rank() over (partition by modifieddate order b ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...