位置: 编程技术 - 正文

详解MySQL中的存取权限(mysql数据库中储存的是)

编辑:rootadmin

推荐整理分享详解MySQL中的存取权限(mysql数据库中储存的是),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql存储数据的原理,mysql数据库中储存的是,mysql数据库中储存的是,mysql的存储,mysql的存储,mysql存储结构详解,mysql存储语句,mysql存储语句,内容如对您有帮助,希望把文章链接给更多的朋友!

看到很多网友提出关于MySQL登录不上服务器的问题,包括有的是在PHP中调用MySQL时发生的不能登录MySQL数据库服务器的问题,以为是PHP出了问题。其实是MySQL权限的问题。

  MySQL的权限系统在MySQL的手册中是很长的一章,我把它打印出来足足印了多页!这里就将我对它的理解简要地写出来,希望能对刚刚接触MySQL的同志有点帮助;有说得不对的地方,也请同志们指出。

  在我了解了MySQL的权限机制后,不由得不赞叹它的严密与巧妙;也许所有的数据库系统都是如此罢,只是别的大型数据库把权限做得不需超级管理员亲自干预数据表而已。

  MySQL的权限保存在名为mysql的数据库中,有user、db、host、tables_priv、columns_priv 等五个表。

  首先,限制用户的登录的,只有 user 表,其中最常用的是 user、host、password这三个字段。其他的select_priv、update_priv、…… 这些字段分别表示该用户是否有select、update、……等权限,这些字段设置为'Y'表示该用户拥有对应的权限,'N'表示用户没有对应的权限。注意,这里指定的权限是全局的,一旦你在user表中给了一个用户select或update权限,他就对这台服务器上任何数据库、任何表拥有上述权限!其中当然包括mysql数据库!!这意味着他可以通过更改user表里的数据非法地获取更大的权限!!!这是非常可怕的,所以建议除了给root用户外,不要在user表中分配权限。特别的,你可以建立一个几乎跟root拥有同样权限的用户(密码可不要告诉别人哟!)在忘记了root密码时就用得到了。在添加一个用户时,如果不指定权限字段的值,它们的默认值都是'N',——也就是这个用户什么权限也没有——你可以放心的在user表中添加用户,因为即使他能登录进来,却什么也干不了。

  还有一个应该注意的问题就是user表中的password字段。试想,既然root用户可以浏览mysql数据库,可以看到user表的password字段,是不是就是看到了其他用户的密码呢?不是的!user表的password字段保存的是用password()函数加密了的用户密码,当用户登录时,服务器将收到的用户输入的密码用password()函数加密,加密得到的字串与user表password字段如能匹配,则认为密码正确。password()没有逆运算,所以任何人无法从一个加密的字串得到密码的明文。同时,如果你手工修改user表,别忘了在更新password字段时一定要用password()函数加密。例如,你要允许一位名为 bill 的用户登录你的服务器,你给他设定一个 的密码,则应该:

详解MySQL中的存取权限(mysql数据库中储存的是)

如果你直接

的话,恐怕他登不上你的服务器,也会到奥索网上发帖子问的。

  注意,每当手工操作了跟权限有关的数据表以后,要执行一条 flush privileges 命令才能使其生效。

  下面的问题就是如何给用户分配权限了。如果你要给一个用户开一个数据库,并把有关这个数据库的所有或部分权限开放给他,这就用到了db表。db表的意义在于,当一个用户请求一个查询时,检测该用户对于他的查询所针对的数据库是否拥有进行该查询操作的权限,有,则允许查询;没有,则进一步咨询tables_priv表。db表的最常用字段是 user、db、和那一大堆有关权限的字段。user,不用说了,就是那个用户的用户名,跟user表中的对应;db,就是要分给他的数据库名。然后就把要给他的权限相对应的权限字段设为'Y'。同样,这些字段的值在不指定的时候默认是'N'。你也可以用GRANT/REVOKE命令给用户分配权限,可以是这样的:

  这样就把针对bill这个数据库的几乎所有的权限给了用户bill。这里没有给的只是grant权限,关于这个权限,建议不要轻易给人,因为用户有了grant权限,也就可以将权限分配给其他用户。值得庆幸的是,拥有grant权限的用户能而且只能将他自己已经拥有的权限分配给别人。

  使用GRANT/REVOKE命令更改了权限后,不须执行 flush privileges 命令就可以使更改生效。

  上面讨论的是给一个用户完全开放一个数据库的问题,如果只想给一个用户一个特定的表的权限,就是 tables_priv 表发挥作用的时候啦。这里的关键性字段是user、db、table_name 。显而易见的,要给一个用户指定一个特定的数据库中特定表的权限,三个关键要素就是:哪个用户(user)、哪个数据库(db)、哪个表(table_name)。它的机理跟db表是类似的,我不必再重复。唯一不同的是这里用了一个SET类型的字段 table_priv 来指定用户对这个表权限,SET的成员有 SELECT, UPDATE, INSERT, DELETE, ALTER, CREATE, DROP, GRANT, INDEX, REFERENCE 等,你可以选择其中任意一个或几个分配给用户。

  在上述提及的几个权限表中以及未提及的host表中,都有一个host字段,它用来区分来自不同主机的、用户名可能相同的人,或者是给同一个用户从不同的主机连接时给予不同的权限。这种用法不很常用,但为了安全起见,建议root用户,如果不需要从远程连接,请将他的host设为 localhost,其他的则可以设为 % ,即任何主机。

详解MySQL中的外键约束问题 使用MySQL开发过数据库驱动的小型web应用程序的人都知道,对关系数据库的表进行创建、检索、更新和删除等操作都是些比较简单的过程。理论上,只要

MySQL的mysqldump工具用法详解 导出要用到MySQL的mysqldump工具,基本用法是:shellmysqldump[OPTIONS]database[tables]如果你不给定任何表,整个数据库将被导出。通过执行mysqldump--help,你能得到

在MySQL中同时查找两张表中的数据的示例 这个例子里面我们从两个表中取出头两行,然后合并到一个表中。在现实中我们常常会遇到这样的情况,在一个数据库中存在两个表,假设表1储存着公

标签: mysql数据库中储存的是

本文链接地址:https://www.jiuchutong.com/biancheng/347967.html 转载请保留说明!

上一篇:Mysql学习心得之插入、更新、删除记录(mysql的心得体会)

下一篇:JDBC连接mysql处理中文时乱码解决办法详解(jdbc连接mysql数据库步骤)

  • 政府补助利得要交企业所得税吗怎么算
  • 税务清算都交什么费用
  • 企业所得税的征收对象是什么
  • 最新个人所得税扣除标准表
  • 员工餐补是放入福利费吗?
  • 固定资产清理费用为什么有进项税额
  • 个税受雇日期以哪个日期
  • 应税职工福利费在应纳税所得额里面吗
  • 退税 增值税
  • 发票丢了企业所得怎么办
  • 存货计提减值准备是什么原则
  • 购入材料用于安装工程
  • 包工包料和包清工
  • 雇主责任险为什么不能立即生效
  • 收到测试费几分钱如何做账
  • 维修开票单位写什么
  • 金税盘怎么做账务处理
  • 微小企业每个季度减免多少税
  • 汇率变动引起的经济危机
  • 建筑物拆除物资包括哪些
  • 员工高温补贴奖励怎么写
  • 网银企业证书年费入哪个科目
  • 食堂购买蔬菜计算公式
  • 预付账款收到发票的会计分录
  • 股权转让受让方要交个人所得税吗
  • macbook设置壁纸后开机变回原样
  • 会计监督作用
  • 发放股票股利的会计分录怎么写
  • 现金流量表的编制基础是权责发生制
  • php7多线程
  • mxoaldr.exe - mxoaldr是什么进程 有什么用
  • 耕地占用税的税收优惠
  • win11怎么打开设置
  • 可以转增资本的有哪些科目
  • 装修费预付款会计分录
  • 编制合并报表的三种理论
  • 小规模纳税人需要缴纳个人所得税吗
  • 火狐十大必用插件
  • 库存现金盘亏盘盈的原因
  • 企业生产经营管理费用包括
  • 顺流交易逆流交易区别
  • 如何在js中给字母排序
  • ChatGPT中国电话不能注册
  • quota命令 显示磁盘已使用的空间与限制
  • 命令行查看git版本
  • 个税系统为什么没有累计数据
  • 公司从银行提取现金4000元备作零星开支
  • 个人对公付款
  • python生成器的应用场景
  • 手机做h5
  • 经营性应付项目的增加为什么调减
  • 不动产进项税抵扣规定一次性抵扣
  • 交强险怎么报警
  • 小规模纳税人购买税控设备
  • 汽车买卖中介
  • 出差在火车上算上班吗
  • 企业资金占用费利率
  • 递延收益与递延负债的区别
  • 收到损坏物品赔偿金如何入账
  • 可供出售金融资产和交易性金融资产
  • 什么是流动负债确认条件是什么
  • 给个体工商户付款可以打到法人卡上吗
  • 法院主要业务活动
  • 会计净资产计算公式
  • 会计主体包括哪些四种
  • 优化加速锁定任务是什么意思
  • 远程桌面修改默认端口
  • debian8安装
  • win8系统怎么设置
  • 在windowsxp的应用程序中,经常有一些菜单选项呈暗灰色
  • python爬取教程
  • 在机上创建一个文件夹
  • js 单引号
  • unity获取父节点
  • shell脚本调用脚本
  • javascript主要学什么
  • js过滤特殊字符串
  • 如何查询税务是否签订三方
  • 价税分离有什么好处
  • 四川省地方税务局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设