Mysql中创建用户帐户的方法

1.create user
create user user [identified by [password] ‘password’]
    [, user [identified by [password] ‘password’]] …
create user用于创建新的mysql账户。要使用create user,您必须拥有mysql数据库的全局create user权限,或拥有insert权限。对于每个账户,create user会在没有权限的mysql.user表中创建一个新记录。如果 账户已经存在,则出现错误。
使用自选的identified by子句,可以为账户给定一个密码。user值和 密码的给定方法和grant语句一样。特别是,要在纯文本中指定密码,需忽略password关键词。要把 密码指定为由password()函数返回的混编值,需包含关键字password。
2.使用grant语句
最好的方法是使用grant语句,因为这样更精确,错误少。从mysql 3.22.11起提供了grant;它的主要用途是来给帐户授权的,但也可用来建立新帐户并同时授权。注意:当mysql运行于no_auto_create_user时要提供新建用户的密码,否则不能创新用户。
下面的示例说明如何使用mysql客户端程序来设置新用户。
首先,使用mysql程序以mysql root用户来连接服务器:
shell> mysql –user=root mysql
如果你为root账户指定了密码,还需要为该mysql命令和本节中的其它命令提供–password或-p选项。
以root连接到服务器上后,可以添加新账户。下面的语句使用grant来设置四个新账户:
mysql> grant all privileges on *.* to ‘monty’@’localhost’
    ->     identified by ‘some_pass’ with grant option;
mysql> grant all privileges on *.* to ‘monty’@’%’
    ->     identified by ‘some_pass’ with grant option;
mysql> grant reload,process on *.* to ‘admin’@’localhost’;
mysql> grant usage on *.* to ‘dummy’@’localhost’;
用grant语句创建的账户有下面的属性:
·         其中两个账户有相同的用户名monty和密码some_pass。两个账户均为超级用户账户,具有完全的权限可以做任何事情。一个账户 (‘monty’@’localhost’)只用于从本机连接时。另一个账户(‘monty’@’%’)可用于从其它主机连接。请注意monty的两个账户必须能从任何主机以monty连接。没有localhost账户,当monty从本机连接时,mysql_install_db创建的localhost的匿名用户账户将占先。结果是,monty将被视为匿名用户。原因是匿名用户账户的host列值比’monty’@’%’账户更具体,这样在user表排序顺序中排在前面。(user表排序的讨论要参考mysql手册)。
·         一个账户有用户名admin,没有密码。该账户只用于从本机连接。授予了reload和process管理权限。这些权限允许admin用户执行mysqladmin reload、mysqladmin refresh和mysqladmin flush-xxx命令,以及mysqladmin processlist。未授予访问数据库的权限。你可以通过grant语句添加此类权限。
·         一个账户有用户名dummy,没有密码。该账户只用于从本机连接。未授予权限。通过grant语句中的usage权限,你可以创建账户而不授予任何权限。它可以将所有全局权限设为’n’。假定你将在以后将具体权限授予该账户。
3.直接操作mysql授权表
    除了grant,你可以直接用insert语句创建相同的账户,然后使用flush privileges告诉服务器重载授权表。
shell> mysql –user=root mysql
mysql> insert into user
    ->     values(‘localhost’,’monty’,password(‘some_pass’),
    ->     ‘y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’);
mysql> insert into user
    ->     values(‘%’,’monty’,password(‘some_pass’),
    ->     ‘y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’,’y’);
mysql> insert into user set host=’localhost’,user=’admin’,
    ->     reload_priv=’y’, process_priv=’y’;
mysql> insert into user (host,user,password)
    ->     values(‘localhost’,’dummy’,”);
mysql> flush privileges;
当你用insert创建账户时使用flush privileges的原因是告诉服务器重读授权表。否则,只有重启服务器后更改方会被注意到。使用 grant,则不需要使用flush privileges。
用insert使用password()函数是为了加密密码。grant语句为你加密密码,因此不需要password()。
‘y’值启用账户权限。对于admin账户,还可以使用更加可读的insert扩充的语法(使用set)。
在为dummy账户的insert语句中,只有user表中的host、user和password列记录为指定的值。没有一个权限列为显式设置,因此mysql将它们均指定为 默认值’n’。这样等同于grant usage的操作。
请注意要设置超级用户账户,只需要创建一个权限列设置为’y’的user表条目。user表权限为全局权限,因此其它 授权表不再需要条目。
4.举几个应用grant创建帐户和授权的例子
下面的例子创建3个账户,允许它们访问专用数据库。每个账户的用户名为custom,密码为obscure。
要想用grant创建账户,使用下面的语句:
shell> mysql –user=root mysql
shell> mysql –user=root mysql
mysql> grant select,insert,update,delete,create,drop
    ->     on bankaccount.*
    ->     to ‘custom’@’localhost’
    ->     identified by ‘obscure’;
mysql> grant select,insert,update,delete,create,drop
    ->     on expenses.*
    ->     to ‘custom’@’whitehouse.gov’
    ->     identified by ‘obscure’;
mysql> grant select,insert,update,delete,create,drop
    ->     on customer.*
    ->     to ‘custom’@’server.domain’
    ->     identified by ‘obscure’;
这3个账户可以用于:
·         第1个账户可以访问bankaccount数据库,但只能从本机访问。
·         第2个账户可以访问expenses数据库,但只能从主机whitehouse.gov访问。
·         第3个账户可以访问customer数据库,但只能从主机server.domain访问。
要想不用grant设置custom账户,使用insert语句直接修改 授权表:
shell> mysql –user=root mysql
mysql> insert into user (host,user,password)
    ->     values(‘localhost’,’custom’,password(‘obscure’));
mysql> insert into user (host,user,password)
    ->     values(‘whitehouse.gov’,’custom’,password(‘obscure’));
mysql> insert into user (host,user,password)
    ->     values(‘server.domain’,’custom’,password(‘obscure’));
mysql> insert into db
    ->     (host,db,user,select_priv,insert_priv,
    ->     update_priv,delete_priv,create_priv,drop_priv)
    ->     values(‘localhost’,’bankaccount’,’custom’,
    ->     ‘y’,’y’,’y’,’y’,’y’,’y’);
mysql> insert into db
    ->     (host,db,user,select_priv,insert_priv,
    ->     update_priv,delete_priv,create_priv,drop_priv)
    ->     values(‘whitehouse.gov’,’expenses’,’custom’,
    ->     ‘y’,’y’,’y’,’y’,’y’,’y’);
mysql> insert into db
    ->     (host,db,user,select_priv,insert_priv,
    ->     update_priv,delete_priv,create_priv,drop_priv)
    ->     values(‘server.domain’,’customer’,’custom’,
    ->     ‘y’,’y’,’y’,’y’,’y’,’y’);
mysql> flush privileges;
 
前3个insert语句在user表中加入条目,允许用户custom从各种主机用给定的密码进行连接,但不授予全局权限(所有权限设置为 默认值’n’)。后面3个insert语句在user表中加入条目,为custom授予bankaccount、expenses和customer数据库权限,但只能从合适的主机访问。通常若直接修改 授权表,则应告诉服务器用flush privileges重载授权表,使权限更改生效。
如果你想要让某个用户从给定域的所有机器访问(例如,mydomain.com),你可以在账户名的主机部分使用含’%’通配符的grant语句:
mysql> grant …
    ->     on *.*
    ->     to ‘myname’@’%.mydomain.com’
    ->     identified by ‘mypass’;
要想通过直接修改授权表来实现:
mysql> insert into user (host,user,password,…)
    ->     values(‘%.mydomain.com’,’myname’,password(‘mypass’),…);
mysql> flush privileges;
5.创建账户的其它方法是使用mysql账户管理功能的第三方程序。phpmyadmin即是一个程序。
 
从mysql删除用户账户
要想移除账户,应使用drop user语句。

启科网络PHP商城系统 启科网络PHP商城系统

启科网络商城系统由启科网络技术开发团队完全自主开发,使用国内最流行高效的PHP程序语言,并用小巧的MySql作为数据库服务器,并且使用Smarty引擎来分离网站程序与前端设计代码,让建立的网站可以自由制作个性化的页面。 系统使用标签作为数据调用格式,网站前台开发人员只要简单学习系统标签功能和使用方法,将标签设置在制作的HTML模板中进行对网站数据、内容、信息等的调用,即可建设出美观、个性的网站。

启科网络PHP商城系统 0 查看详情 启科网络PHP商城系统

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1081875.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
Less和Sass属性插值:如何用Less实现Sass中@function类似的动态CSS变量生成?
上一篇 2025年12月2日 19:04:22
Go与PHP FastCGI集成:利用反向代理构建混合Web服务
下一篇 2025年12月2日 19:04:26

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    1000
  • 修复Django电商项目中AJAX过滤产品列表图片不显示问题

    在Django电商项目中,当使用AJAX动态加载过滤后的产品列表时,常遇到图片无法正常显示的问题。这通常是由于前端模板中图片加载方式(如data-setbg属性结合JavaScript库)与AJAX动态内容更新机制不兼容所致。解决方案是直接在AJAX返回的HTML中使用标准的标签来渲染图片,确保浏览…

    2026年5月10日
    700
  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • Golang JSON序列化:控制敏感字段暴露的最佳实践

    本教程探讨golang中如何高效控制结构体字段在json序列化时的可见性。当需要将包含敏感信息的结构体数组转换为json响应时,通过利用`encoding/json`包提供的结构体标签,特别是`json:”-“`,可以轻松实现对特定字段的忽略,从而避免敏感数据泄露,确保api…

    2026年5月10日
    300
  • 怎么在PHP代码中实现图片上传功能_PHP图片上传功能实现与安全处理教程

    首先创建含enctype的HTML表单,再用PHP接收文件,检查目录、移动临时文件,验证类型与大小,生成唯一文件名,并调整php.ini限制以确保上传成功。 如果您尝试在PHP项目中添加图片上传功能,但服务器无法正确接收或保存文件,则可能是由于表单配置、文件处理逻辑或安全限制的问题。以下是实现该功能…

    2026年5月10日
    300
  • 获取日期中的周数:CodeIgniter 教程

    本教程旨在帮助开发者在 CodeIgniter 框架中,从日期字符串中准确提取周数。我们将使用 PHP 内置的 DateTime 类,并提供详细的代码示例和注意事项,确保您能够轻松地在项目中实现此功能。 使用 DateTime 类获取周数 PHP 的 DateTime 类提供了一种便捷的方式来处理日…

    2026年5月10日
    100
  • 比特币新手教程 比特币交易平台有哪些

    比特币是一种去中心化的数字货币,基于区块链技术实现点对点交易,具有匿名性、有限发行和不可篡改等特点;新手可通过交易所购买,P2P交易获得比特币,常用平台包括Binance、OKX和Huobi;交易流程包括注册账户、实名认证、绑定支付方式、充值法币并下单购买,可选择市价单或限价单;比特币存储方式有交易…

    2026年5月10日
    000
  • c++中的SFINAE技术是什么_c++模板编程中的SFINAE原理与应用

    SFINAE 是“替换失败不是错误”的原则,指模板实例化时若参数替换导致错误,只要存在其他合法候选,编译器不报错而是继续重载决议。它用于条件启用模板、类型检测等场景,如通过 decltype 或 enable_if 控制函数重载,实现类型特征判断。尽管 C++20 引入 Concepts 简化了部分…

    2026年5月10日
    000
  • HTML如何隐藏滚动条或去除滚动条

    滚动条可以存在也可以不存在,本文主要介绍了html 隐藏滚动条和去除滚动条的方法的相关资料,大家一起来学习一下html隐藏滚动条或去除滚动条的方法吧。 1. html 标签加属性 XML/HTML Code复制内容到剪贴板 2.body中加入以下代码 立即学习“前端免费学习笔记(深入)”; html…

    用户投稿 2026年5月10日
    100
  • Go语言mgo查询构建:深入理解bson.M与日期范围查询的正确实践

    本文旨在解决go语言mgo库中构建复杂查询时,特别是涉及嵌套`bson.m`和日期范围筛选的常见错误。我们将深入剖析`bson.m`的类型特性,解释为何直接索引`interface{}`会导致“invalid operation”错误,并提供一种推荐的、结构清晰的代码重构方案,以确保查询条件能够正确…

    2026年5月10日
    100
  • vscode上怎么运行html_vscode上运行html步骤【指南】

    首先保存文件为.html格式,再通过浏览器或Live Server插件打开预览;推荐安装Live Server实现本地服务器运行与实时刷新,提升开发体验。 在 VS Code 上运行 HTML 文件并不需要复杂的配置,只需几个简单步骤即可预览页面效果。VS Code 本身是一个代码编辑器,不直接运行…

    2026年5月10日
    100
  • 修复点击时按钮抖动:CSS垂直对齐实践

    本文探讨了在Web开发中,交互式按钮(如播放/暂停按钮)在点击时发生意外垂直位移的问题。通过分析CSS样式变化对元素布局的影响,我们发现这是由于按钮不同状态下的边框样式和内边距改变,以及默认的垂直对齐行为共同作用所致。核心解决方案是利用CSS的vertical-align属性,将其设置为middle…

    2026年5月10日
    100
  • Golang goroutine与channel调试技巧

    使用go run -race检测数据竞争,结合runtime.NumGoroutine监控协程数量,通过pprof分析阻塞调用栈,利用select超时避免永久阻塞,有效排查goroutine泄漏、死锁和数据竞争问题。 Go语言的goroutine和channel是并发编程的核心,但它们也带来了调试上…

    2026年5月10日
    000
  • 页面中文本域的值怎么设置

    标签定义多行的文本输入控件。 文本区中可容纳无限数量的文本,其中的文本的默认字体是等宽字体(通常是 Courier)。 可以通过 cols 和 rows 属性来规定 textarea 的尺寸,不过更好的办法是使用 CSS 的 height 和 width 属性。 注释:在文本输入区内的文本行间,用 …

    2026年5月10日
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • 《魔兽世界》将于6月11日开启国服回归技术测试

    《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试

    《%ign%ignore_a_1%re_a_1%》官方宣布,将于6月11日开启国服回归技术测试,时间为7天,并称可以在6月内正式开服,玩家们可以访问官网下载战网客户端并预下载“巫妖王之怒”客户端,技术测试详情见下图。 WordAi WordAI是一个AI驱动的内容重写平台 53 查看详情 以上就是《…

    2026年5月10日 用户投稿
    200
  • php常量怎么用_PHP常量(define/const)定义与使用方法

    PHP中可通过define函数和const关键字定义常量,用于存储不可变值。define适用于全局作用域,支持动态名称和条件定义,如define(‘SITE_NAME’, ‘MyWebsite’);const在编译时生效,语法简洁但限制多,只能在类或全…

    2026年5月10日
    000
  • 如何在HTML中插入表单元素_HTML表单控件与输入类型使用指南

    HTML表单通过标签构建,包含action和method属性定义数据提交目标与方式,常用input类型如text、password、email等适配不同输入需求,配合label、required、placeholder提升可用性,结合textarea、select、button等控件实现完整交互,是…

    2026年5月10日
    300
  • HTML5网页如何实现手势操作 HTML5网页移动端交互的处理技巧

    首先利用原生touch事件实现滑动判断,再通过preventDefault解决滚动冲突,接着引入Hammer.js处理复杂手势,最后通过优化点击区域、避免事件冲突和增加视觉反馈提升体验。 在移动端浏览器中,HTML5网页可以通过触摸事件实现手势操作,提升用户体验。虽然原生JavaScript提供了基…

    2026年5月10日
    000
  • 创建指定大小并填充特定数据的Golang文件教程

    本文将介绍如何使用Golang创建一个指定大小的文件,并用特定数据填充它。我们将使用 `os` 包提供的函数来创建和截断文件,从而实现快速生成大文件的目的。示例代码展示了如何创建一个10MB的文件,并将其填充为全零数据。掌握这些方法,可以方便地在例如日志系统或磁盘队列等场景中,预先创建测试文件或初始…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信