在MySQL中修改密码及访问限制的设置方法详解

MySQL是一个真正的多用户、多线程SQL数据库服务器。MySQL是以一个客户机/服务器结构的实现,它由一个服务器守护程序mysqld和很多不同的客户程序和库组成。

由于其源码的开放性及稳定性,且与网站流行编 挥镅 PHP的完美结合,现在很多站点都利用其当作后端数据库,使其获得了广泛应用。处于安全方面的考虑,需要为每一用户赋于对不同数据库的访问限制,以满足不同用户的要求。下面就分别讨论,供大家参考。   
  一、MySQL修改密码方法总结
  首先要说明一点的是:一般情况下,修改MySQL密码是需要有mysql里的root权限的,这样一般用户是无法更改密码的,除非请求管理员帮助修改。   
  方法一   
  使用phpMyAdmin
  (图形化管理MySql数据库的工具),这是最简单的,直接用SQL语句修改mysql数据库库的user表,不过别忘了使用PASSWORD函数,插入用户用Insert命令,修改用户用Update命令,删除用Delete命令。在本节后面有数据表user字段的详细介绍。   
  方法二   
  使用mysqladmin。输入  
  mysqladmin -u root -p oldpassword newpasswd   
  执行这个命令后,需要输入root的原密码,这样root的密码将改为newpasswd。同样,把命令里的root改为你的用户名,你就可以改你自己的密码了。
  当然如果你的mysqladmin连接不上mysql
  server,或者你没有办法执行mysqladmin,那么这种方法就是无效的,而且mysqladmin无法把密码清空。   
  下面的方法都在mysql提示符下使用,且必须有mysql的root权限:   
  方法三   
  mysql> INSERT INTO mysql.user (Host,User,Password) VALUES
  (‘%’,’system’, PASSWORD(‘manager’));
  mysql> FLUSH PRIVILEGES   
  确切地说这是在增加一个用户,用户名为system,密码为manager。注意要使用PASSWORD函数,然后还要使用FLUSH
  PRIVILEGES来执行确认。   
  方法四   
  和方法三一样,只是使用了REPLACE语句
  mysql> REPLACE INTO mysql.user (Host,User,Password)
  VALUES(‘%’,’system’,PASSWORD(‘manager’));
  mysql> FLUSH PRIVILEGES  
  方法五   
  使用SET PASSWORD语句   
  mysql> SET PASSWORD FOR system@”%” = PASSWORD(‘manager’);   
  你也必须使用PASSWORD()函数,但是不需要使用FLUSH PRIVILEGES来执行确认。   
  方法六   
  使用GRANT … IDENTIFIED BY语句,来进行授权。   
  mysql> GRANT USAGE ON *.* TO system@”%” IDENTIFIED BY ‘manager’;   
  这里PASSWORD()函数是不必要的,也不需要使用FLUSH PRIVILEGES来执行确认。   
  注:PASSWORD()函数作用是为口令字加密,在程序中MySql自动解释。  
  二、MySql中访问限制的设置方法
  我们采用两种方法来设置用户。
  进入到Mysql执行目录下(通常是c:\mysql\bin)。输入mysqld-shareware.exe,输入mysql
  –user=root mysql ,不然不能添加新用户。进入到mysql>提示符下进行操作。   
  假设我们要建立一个超级用户,用户名为system,用户口令为manager。  
  方法一  
  用Grant 命令授权,输入的代码如下:
  mysql>GRANT ALL PRIVILEGES ON *.* TO system@localhost IDENTIFIED BY
  ’manager’ WITH GRANT OPTION;   
  应显示:Query OK, 0 rows affected (0.38 sec)   
  方法二   
  对用户的每一项权限进行设置:   
  mysql>INSERT INTO user
  VALUES(‘localhost’,’system’,PASSWORD(‘manager’),
  ’Y’,’Y’,’Y’,’Y’,’Y’,’Y’,’Y’,’Y’,’Y’,’Y’,’Y’,’Y’,’Y’,’Y’);
  对于3.22.34版本的MySQL,这里共14个”Y”,其相应的权限如下(按字段顺序排列):   
  权限 表列名称 相应解释 使用范围
  select Select_priv 只有在真正从一个表中检索时才需要select权限 表
  insert Insert_priv 允许您把新行插入到一个存在的表中 表
  update Update_priv 允许你用新值更新现存表中行的列 表
  delete Delete_priv 允许你删除满足条件的行 表
  create Create_priv 允许你创建新的数据库和表 数据库、表或索引
  drop Drop_priv 抛弃(删除)现存的数据库和表 数据库或表
  reload Reload_priv 允许您告诉服务器再读入授权表 服务器管理
  shutdown Shutdown_priv 可能被滥用(通过终止服务器拒绝为其他用户服务) 服务器管理
  process Process_priv 允许您察看当前执行的查询的普通文本,包括设定或改变口令查询 服务器管理
  file File_priv 权限可以被滥用在服务器上读取任何可读的文件到数据库表 服务器上的文件存取
  grant Grant_priv 允许你把你自己拥有的那些权限授给其他的用户 数据库或表
  references References_priv 允许你打开和关闭记录文件 数据库或表
  index Index_priv 允许你创建或抛弃(删除)索引 表
  alter Alter_priv 允许您改变表格,可以用于通过重新命名表来推翻权限系统 表  
  如果创建用户时只有select、insert、update和delete权限,则允许用户只能在一个数据库现有的表上实施操作.
  下面就可以创建我们要用到的数据库了,我们直接输入. 例如:我们要创建数据库名为XinXiKu,可用如下代码:  
  mysql>create database XinXiKu;   
  应显示:Query OK, 1 row affected (0.00 sec)

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 03:03:46
下一篇 2025年11月8日 03:09:41

相关推荐

  • 解决Django ORM在PostgreSQL中正则表达式词边界失效的问题

    本文旨在解决Django ORM在使用PostgreSQL数据库时,正则表达式中(词边界)无法正确匹配的问题。许多开发者在使用text__regex=r’some’等模式时会发现其失效。究其原因,在PostgreSQL的正则表达式中并非词边界,而是退格符。正确的词边界匹配符应…

    2025年12月14日
    000
  • Django ORM与PostgreSQL:解决正则表达式词边界无效问题

    在使用Django ORM通过__regex查询PostgreSQL数据库时,Python正则表达式中的b(词边界)元字符可能无法按预期工作。这是因为PostgreSQL的正则表达式引擎将b解释为退格符,而非词边界。本文将详细解释此问题,并提供解决方案:使用PostgreSQL特有的词边界元字符y来…

    2025年12月14日
    000
  • PostgreSQL正则表达式中的单词边界:与y的辨析与应用

    在使用Django ORM对PostgreSQL数据库执行正则表达式查询时,开发者常会遇到b(单词边界)字符无法按预期工作的问题。这并非Django ORM的缺陷,而是由于PostgreSQL的正则表达式语法中,b代表退格符而非单词边界。正确的单词边界元字符应为y。本文将深入探讨这一差异,并提供在D…

    2025年12月14日
    000
  • 解决Django ORM中PostgreSQL正则表达式字边界失效问题

    在Django ORM中使用PostgreSQL数据库时,开发者可能会发现正则表达式中的b(字边界)无法正确匹配。这是因为PostgreSQL的正则表达式语法与Python标准库有所不同,b在PostgreSQL中被解释为退格符而非字边界。本文将详细解释这一差异,并提供解决方案:在PostgreSQ…

    2025年12月14日
    000
  • Django ORM在PostgreSQL中正确使用正则表达式单词边界y

    本文旨在解决Django ORM在PostgreSQL数据库中使用正则表达式时,单词边界元字符无法按预期工作的问题。核心原因是PostgreSQL的正则表达式语法中,并非表示单词边界,而是退格符。正确的解决方案是使用PostgreSQL特有的y元字符来匹配单词的起始或结束位置,从而实现精确的单词匹配…

    2025年12月14日
    000
  • Python如何制作网络爬虫?Scrapy框架

    使用python和scrapy制作网络爬虫的核心流程包括:安装scrapy、创建项目、定义spider、编写解析逻辑并利用选择器提取数据;2. scrapy通过设置user-agent、使用代理ip池、配置下载延迟和autothrottle、集成selenium或scrapy-splash等方式应对…

    2025年12月14日
    000
  • Python如何实现网页爬虫?requests+BeautifulSoup

    使用python实现网页爬虫的核心流程包括:发起请求、获取响应、解析html、提取数据;2. 选择requests和beautifulsoup组合的原因是其学习曲线平缓、功能强大且灵活,requests库封装了http请求的复杂性,beautifulsoup能高效解析不规范的html结构;3. 应对…

    2025年12月14日
    000
  • SQLAlchemy 将 UUID 主键映射为字符串问题的解决与实践

    本文旨在解决在使用 SQLAlchemy (SQLModel) 时,UUID 主键被错误地映射为字符串类型的问题。通过分析问题原因,提供解决方案,并给出示例代码,帮助开发者正确处理 UUID 类型,确保数据类型的一致性,避免潜在的类型错误。本文适合使用 SQLAlchemy 和 SQLModel 进…

    2025年12月14日
    000
  • Python怎样操作MariaDB数据库?mariadb连接器

    python操作mariadb应优先选择pymysql或mysql-connector-python,pymysql因纯python实现、安装简便、社区活跃而更适合大多数场景;2. 防止sql注入必须使用参数化查询,通过占位符(如%s)与参数元组分离sql结构与数据,避免恶意输入篡改语句;3. 事务…

    2025年12月14日
    000
  • 如何用Python源码开发追剧提醒系统 Python源码定时任务与接口集成

    要开发python追剧提醒系统,关键步骤如下:1.选择数据库存储信息,小型项目用sqlite,大型用mysql;2.调用视频源api或使用爬虫获取更新数据,注意频率限制和合规性;3.使用schedule或apscheduler实现定时任务,前者适合简单任务,后者支持复杂调度;4.通过邮件、短信或微信…

    2025年12月14日 好文分享
    000
  • 如何使用Python构建注塑产品的尺寸异常检测?

    构建注塑产品尺寸异常检测系统,首先要明确答案:通过python构建一套从数据采集到异常识别再到预警反馈的自动化系统,能够高效识别注塑产品尺寸异常。具体步骤包括:①从mes系统、csv/excel、传感器等来源采集数据,使用pandas进行整合;②清洗数据,处理缺失值与异常值,进行标准化;③结合工艺知…

    2025年12月14日 好文分享
    000
  • Python如何操作MongoDB?NoSQL数据库实战

    python操作mongodb的核心依赖pymongo库,其核心步骤包括:1. 安装pymongo;2. 建立与mongodb的连接;3. 选择数据库和集合;4. 执行增删改查操作;5. 使用聚合和批量操作提升性能;6. 关闭连接。mongodb作为文档型数据库,与传统关系型数据库相比,具有灵活的无…

    2025年12月14日 好文分享
    000
  • 连接 MySQL 5.1 数据库的 Python 教程

    本文档旨在指导开发者如何使用 Python 连接到 MySQL 5.1 数据库。由于 MySQL 5.1 较为古老,现代的 MySQL 连接器可能存在兼容性问题。本文将介绍如何使用 mysql-connector-python 驱动,并配置相应的参数,以成功建立连接。同时,本文也强烈建议升级 MyS…

    2025年12月14日
    000
  • Python连接MySQL 5.1:克服旧版认证与字符集兼容性挑战

    本教程详细阐述了如何使用Python 3和mysql.connector库成功连接到老旧的MySQL 5.1数据库。文章重点介绍了解决旧版认证协议和字符集兼容性问题的关键配置,特别是use_pure=True和charset=’utf8’的重要性,并提供了可运行的代码示例。同…

    2025年12月14日
    000
  • Python如何做自动化爬虫?Scrapy框架指南

    scrapy是当前最成熟、功能最强大的python自动化爬虫框架,其核心优势在于提供从请求发起到数据存储的完整解决方案。1. scrapy基于异步io实现高并发,提升爬取效率;2. 其模块化设计支持清晰架构与高度扩展性;3. 中间件系统灵活应对反爬策略;4. 内置item与pipeline实现数据结…

    2025年12月14日 好文分享
    000
  • 如何实现Python与数据库的批量数据交互?高效IO方案

    优化python数据库操作的核心在于减少交互次数和高效利用io。1.使用批量操作避免单条sql循环执行,如psycopg2的execute_batch或pymysql的executemany;2.通过连接池管理连接,减少频繁创建销毁连接的开销,并根据数据库性能、并发量合理设置连接池大小;3.采用异步…

    2025年12月14日 好文分享
    000
  • Python如何实现网络爬虫?Scrapy框架教程

    要实现网络爬虫,python 中最常用、功能强大的框架之一是 scrapy。1. 安装 scrapy 并创建项目:使用 pip install scrapy 安装,并通过 scrapy startproject myproject 创建项目;2. 编写第一个爬虫:在 spiders 目录下新建 py…

    2025年12月14日 好文分享
    000
  • 怎样用Python构建端到端异常检测流水线?完整架构

    数据预处理在异常检测中扮演提升数据质量、统一数据尺度、提取有效信息和适配模型输入四大核心角色。1. 提升数据质量:处理缺失值、异常值和噪声,避免模型学习错误模式;2. 统一数据尺度:通过标准化或归一化消除特征量纲差异,确保模型公平对待所有特征;3. 提取有效信息:进行特征工程,如创建滞后特征、滚动统…

    2025年12月14日 好文分享
    000
  • Python中如何实现并发编程?asyncio协程详解

    asyncio和协程是python中处理i/o密集型任务的高效并发方案,其核心在于通过事件循环实现单线程内的合作式多任务调度。1. 协程由async def定义,通过await暂停执行并释放控制权给事件循环;2. 事件循环负责监控和调度就绪的协程,避免阻塞;3. 使用asyncio.run()启动事…

    2025年12月14日 好文分享
    000
  • Python中如何实现定时任务?APScheduler详细配置

    实现python定时任务的核心工具是apscheduler,其使用步骤如下:1. 安装apscheduler;2. 根据应用场景选择调度器,如backgroundscheduler适合后台运行;3. 配置调度器,包括时区、任务存储、执行器及任务默认属性;4. 使用add_job()方法添加任务,并指…

    2025年12月14日 好文分享
    000

发表回复

登录后才能评论
关注微信