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模型图 , 确认需求信息的正确和完整.
设计数据库步骤
- 收集信息
- 与该系统有关人员进行交流 , 座谈 , 充分了解用户需求 , 理解数据库需要完成的任务.
- 标识数据库要管理的关键对象或实体,实体一般是名词
- 标识每个实体需要存储的详细信息[Attribute]
- 标识实体之间的关系[Relationship]
标识实体[Entity]
绘制E-R图和数据库模型图
E-R图即数据库设计的图形化表达方式 , 也称为实体-关系图
关系模式 : 用二维表的形式表示实体和实体间联系的数据模型即关系模式R(U)
绘制数据库模型图的步骤 :
- 新建数据库模型图
- 添加实体
- 添加数据列及相应的属性
- 添加实体之间的映射关系
三大范式
问题 : 为什么需要数据规范化?
不合规范的表设计
- 信息重复
- 更新异常
- 插入异常
- 无法正确表示信息
- 删除异常
- 丢失有效信息
第一范式 (1st NF)
第一范式的目标是确保每列的原子性,如果每列都是不可再分的最小数据单元,则满足第一范式
第二范式(2nd NF)
第二范式要求每个表只描述一件事情
第三范式(3rd NF)
如果一个关系满足第二范式,并且除了主键以外的其他列都不传递依赖于主键列,则满足第三范式.
规范化和性能的关系
为满足某种商业目标 , 数据库性能比规范化数据库更重要
在数据规范化的同时 , 要综合考虑数据库的性能
通过在给定的表中添加额外的字段,以大量减少需要从中搜索信息所需的时间
通过在给定的表中插入计算列,以方便查询
mysql学习【第6篇】:权限和数据库设计的更多相关文章
- 数据库MySQL学习笔记高级篇
数据库MySQL学习笔记高级篇 写在前面 学习链接:数据库 MySQL 视频教程全集 1. mysql的架构介绍 mysql简介 概述 高级Mysql 完整的mysql优化需要很深的功底,大公司甚至有 ...
- 【大白话系统】MySQL 学习总结 之 缓冲池(Buffer Pool) 的设计原理和管理机制
一.缓冲池(Buffer Pool)的地位 在<MySQL 学习总结 之 InnoDB 存储引擎的架构设计>中,我们就讲到,缓冲池是 InnoDB 存储引擎中最重要的组件.因为为了提高 M ...
- 【大白话系列】MySQL 学习总结 之 COMPACT 行格式的设计原理
如果大家对我的 [大白话系列]MySQL 学习总结系列 感兴趣的话,可以点击关注一波. 一.回顾 MySQL 学习总结系列至此已经第七节了. 从大方向:我们已经学习了 MySQL 的架构设计.Inno ...
- 权限管理数据库设计_Rev1
贴出来自身接触项目以来所接触过的一些企业管理信息系统权限部门的一个通用数据库设计初稿: 设计的文字解释以及各部分的作用等确定可行会再进行描述: 图: 如果有不同意见请轻拍!
- MVC基于角色权限控制--数据库设计
在网站后台设计过程中都会遇上权限控制这一问题 当前较为流行的解决方案是基于角色的权限管理 基本思路如下 分别建立 用户信息表.角色信息表.权限信息表 让用户和角色关联,角色和权限关联,当用户访问时,通 ...
- SpringSecurity 3.2入门(8)自定义权限控制数据库设计
; -- ---------------------------- -- Table structure for t_system_authority_info -- ---------------- ...
- MySQL学习记录(导入Excel表到数据库,并筛选条件输出)
附上:重置mysql账号密码方法 ubuntu系统下mysql重置密码和修改密码操作 - skh2015java的博客 - CSDN博客(改完重启,登录mysql要root/sudo权限) Cento ...
- MySQL学习笔记Windows篇<一> Welcome to MySQL
MySQL安装完毕后没有图形化操作界面,图形化管理界面需要另行安装,个人比较喜欢Navicat,界面更像SQLserver: 此篇学习笔记所有操作均使用命令行中完成: 1.开启/停止服务 使用MySQ ...
- MySQL学习笔记二:权限管理
1. 创建和删除用户,mysql中的用户是由用户名和主机名来确定的 create user "user_name@host_name" identified by passwd; ...
随机推荐
- [WPF] VisualBrush 中的布局
今天插一篇随笔.说一说上周五遇到的一个布局问题,问题大概是这样的:需要在一个快区域上添加一张透明的背景图片,由于区域较大.并且宽高都不是固定大小,图片较小 所以图片需要居中显示.除此之外还需要在图片的 ...
- 解决:Reading table information for completion of table and column names
mysql -A不预读数据库信息(use dbname 更快)—Reading table information for completion of table and column names Y ...
- Android MediaPlayer播放项目res/raw和res/assets下的音频文件
1..播放res/raw //方法一:根据音频文件的ID来创建MediaPlayer MediaPlayer mp = new MediaPlayer(this,R.raw.test); mp.sta ...
- slackware在vagrant中使用
slackware以简洁干净的系统闻名于世,如果你想学习了解linux,那么slackware是一个很好的选择,其他linux不是不好,他们都太复杂了,复杂的你不知道从哪里开始. 所以,还是slack ...
- Win10连接远程桌面的时候提示您的凭证不工作该怎么办?
Win10连接远程桌面的时候提示您的凭证不工作该怎么办?Win10连接远程桌面的时候,提示“您的凭证不工作”.原有保存的远程帐号密码无法使用,导致远程登录系统失败.我这里总结下自己解决的方法,分享给大 ...
- zookeeper入门及使用(二)- 状态查看
查看服务的角色,看Mode字段,有follower及leader [root@c7bit1 bin]# echo stat | nc 127.0.0.1 2181 Zookeeper version: ...
- C#访问gsoap的服务
C++开发一个webservice,然后C#开发客户端,这样就需要C#的客户端访问gsoap的服务端.(大家都知道gsoap是C/C++开发webservice的最佳利器) 为什么不考虑直接用wcf开 ...
- 使用docker安装tomcat服务
1. 拉取官方tomcat镜像 docker pull tomcat 2. 创建tomcat容器目录 [root@WSyHRQ171356 /]# mkdir /tomcat/test 3. 创建测试 ...
- Android利用Mediapalyer播放本地资源文件声音
首先在res下创建raw,然后将mp3音乐拷贝到raw下 直接贴代码吧 //开始播放声音 public class PlayVoice { private static MediaPlayer med ...
- spark StructType的应用,用在处理mongoDB keyvalue
近期在处理mongoDB 数据的时候,遇到了非常奇怪的格式,账号密码的日志都追加在一条记录里面,要取一个密码的时长和所有密码的平均时长就非常繁琐. 用了各种迭代计算,非常困难,而且printschem ...