热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MySQL数据库(五)——用户管理、pymysql模块

用户权限管理、pymysql模块一、用户管理(权限管理)在MySQL中自带的mysql数据库中有4个表用于用户管理的二、pymysql模块pymysql模块用于Python程序与M

用户权限管理、pymysql模块

一、用户管理(权限管理)

在MySQL中自带的mysql数据库中有4个表用于用户管理的

# 优先级从高到低
user > db > tables_priv > columns_priv
user #该表放行的权限,针对:所有数据,所有库下所有表,以及表下的所有字段
db #该表放行的权限,针对:某一数据库,该数据库下的所有表,以及表下的所有字段
tables_priv #该表放行的权限。针对:某一张表,以及该表下的所有字段
columns_priv #该表放行的权限,针对:某一个字段
# 1.创建用户      主机号是客户端的主机地址,% 代表任意一条主机
create user 用户名@"主机地址" identified by 密码;
eg:create user tom@
localhost identified by 123;
# 2.授权 []中为可选内容,with grant option 是给用户添加授权权限,all 代表所有除了grant以外的权限。若是用户名不存,则会先创建该用户名,再授权。 grant [权限名字:select、insert、update……、all] on 数据库名.表名 to 用户名@"主机地址" [with grant option];
      # 权限可以是授予数据库、表、某些字段的权限
eg: grant all on mydb.
* to tom@127.0.0.1 grant all on mydb.teacher to tom@127.0.0.1 with grant option
# 3.解除授权 revoke [权限名字:select、insert、delete……all] on 数据库名.表名 from 用户名@"主机地址"
eg:revoke select on mydb.
* from tom@127.0.0.1;
# 4.删除用户 drop user 用户名@"主机地址"

二、pymysql模块

pymysql模块用于Python程序与MySQL的连接

#安装
pip3 install pymysql

1、查询

# 1.连接数据库,创建连接,获得一个连接对象
cOnn= pymysql.Connect(
    host=127.0.0.1,  # 主机地址
    user=root,  # 用户名
    password=hf19970124,  # 密码
    database=mydb,  # 数据库名称
    port=3306,  # 端口号  可选
    charset=utf8  # 编码   可选
)

# 2.获取游标对象,游标封装的读和写的操作
cursor = conn.cursor(pymysql.cursors.DictCursor)  # pymysql.cursors.DictCursor指定返回的结果为字典,不写默认为元组

# 3.查询语句
sql = "select * from teacher where name-‘%s‘ and password = ‘%s‘%(‘tom‘,‘123‘)"   # 注意%s需要加引号,并且单引号、双引号的嵌套使用

# 4.执行sql语句,如果是查询,返回查询的条数
res = cursor.execute(sql)
print(res)

# 5.获取查询的结果
print(cursor.fetchall())
# print(cursor.fetchone())


# 6.关闭连接
cursor.close()
conn.close()
2、fetchall、fetchone、fetchmany与scroll
fetchall、fetchone、fetchmany 用于获取查询结果
scroll 用于设置游标的位置
cursor.fetchall()   # 获取所有的结果
cursor.fetchone()   #获取结果中的第一条数据,取出一天,游标的位置就往下移一个,下一次取从新位置开始
cursor.fetchmany(size)   # 获取size条数据


# scroll  可用于设置游标的位置
cursor.scroll(1,mode=‘relative‘)    # 相对位置,游标位置从当前位置后移一个,下一次取结果,从第二条数据开始
cursor.scroll(-1)     # 默认为相对位置,游标位置从当前位置退一个
cursor.scroll(3,mode=‘absolute‘) # 绝对位置,游标位置从头开始移动3个
3、增、删、改数据
(1)在增删改数据的时候,执行完SQL语句,必须提交  conn.commint()
技术分享图片技术分享图片
# 在增删改数据的时候,执行完SQL语句,必须提交,否则在数据库中的数据不会改变
import pymysql

conn = pymysql.Connect(
    host=127.0.0.1,
    user=root,
    password=hf19970124,
    database=mydb,
    port=3306,
    charset=utf8
)

cursor = conn.cursor(pymysql.cursors.DictCursor)

sql = insert into stu values(1,"ton"),(2 ,"jack")
# sql = ‘update stu set name="TOM" where id = 2‘
# sql = ‘delete from stu where name = "tom"‘
 
cursor.execute(sql)

conn.commit()  # 提交

cursor.close()
conn.close()
提交 conn.commit()

(2)修改数据时,如果发生错误,数据应该回到起始值,如果修改失败,就会抛出异常,可以对异常进行处理,只要抛出异常就将数据撤销  conn.roback()

技术分享图片技术分享图片
import pymysql
# 创建链接得到一个链接对象
cOnn= pymysql.Connect(
    host="127.0.0.1",    # 数据库服务器主机地址
    user="root",  # 用户名
    password="admin", # 密码
    database="day42", #数据库名称
    port=3306, # 端口号 可选 整型
    charset="utf8" # 编码  可选
)
# 获取游标对象  pymysql.cursors.DictCursor指定 返回的结果类型 为字典  默认是元祖类型
cursor = conn.cursor(pymysql.cursors.DictCursor)

try:
    cursor.execute("update moneyTable set mOney= money - 50 where name = ‘小明‘")
    #如果小花的账户出问题了 无法更新数据 那就需要回滚
    cursor.execute("update moneyTable set mOney= money + 50 where name = ‘小花‘")
    conn.commit()
except:
    conn.rollback()



cursor.close()
conn.close()
撤销 conn.roback()

MySQL数据库(五)—— 用户管理、pymysql模块


推荐阅读
  • 在 Axublog 1.1.0 版本的 `c_login.php` 文件中发现了一个严重的 SQL 注入漏洞。该漏洞允许攻击者通过操纵登录请求中的参数,注入恶意 SQL 代码,从而可能获取敏感信息或对数据库进行未授权操作。建议用户尽快更新到最新版本并采取相应的安全措施以防止潜在的风险。 ... [详细]
  • Python 伦理黑客技术:深入探讨后门攻击(第三部分)
    在《Python 伦理黑客技术:深入探讨后门攻击(第三部分)》中,作者详细分析了后门攻击中的Socket问题。由于TCP协议基于流,难以确定消息批次的结束点,这给后门攻击的实现带来了挑战。为了解决这一问题,文章提出了一系列有效的技术方案,包括使用特定的分隔符和长度前缀,以确保数据包的准确传输和解析。这些方法不仅提高了攻击的隐蔽性和可靠性,还为安全研究人员提供了宝贵的参考。 ... [详细]
  • 在Conda环境中高效配置并安装PyTorch和TensorFlow GPU版的方法如下:首先,创建一个新的Conda环境以避免与基础环境发生冲突,例如使用 `conda create -n pytorch_gpu python=3.7` 命令。接着,激活该环境,确保所有依赖项都正确安装。此外,建议在安装过程中指定CUDA版本,以确保与GPU兼容性。通过这些步骤,可以确保PyTorch和TensorFlow GPU版的顺利安装和运行。 ... [详细]
  • 蚂蚁课堂:性能测试工具深度解析——JMeter应用与实践
    蚂蚁课堂:性能测试工具深度解析——JMeter应用与实践 ... [详细]
  • 在最近的项目中,我们广泛使用了Qt框架的网络库,过程中遇到了一些挑战和问题。本文旨在记录这些经验和解决方案,以便日后参考。鉴于我们的客户端GUI完全基于Qt开发,我们期望利用其强大的网络功能进行Fiddler网络数据包的捕获与分析,以提升开发效率和应用性能。 ... [详细]
  • 在 iOS 开发中,经常会遇到 `@(YES)`、`@[firstViewController]` 以及 `@{@a:@b}` 这样的语法糖。这些简化的写法分别用于初始化布尔值、数组和字典对象,能够显著提高代码的可读性和编写效率。例如,`@(YES)` 可以快速创建一个布尔值对象,`@[firstViewController]` 则用于创建包含单个元素的数组,而 `@{@a:@b}` 则用于创建键值对字典。理解这些语法糖的使用方法,有助于开发者更加高效地进行编码。 ... [详细]
  • Unity3D 中 AsyncOperation 实现异步场景加载及进度显示优化技巧
    在Unity3D中,通过使用`AsyncOperation`可以实现高效的异步场景加载,并结合进度条显示来提升用户体验。本文详细介绍了如何利用`AsyncOperation`进行异步加载,并提供了优化技巧,包括进度条的动态更新和加载过程中的性能优化方法。此外,还探讨了如何处理加载过程中可能出现的异常情况,确保加载过程的稳定性和可靠性。 ... [详细]
  • 深入解析Java虚拟机的内存分区与管理机制
    Java虚拟机的内存分区与管理机制复杂且精细。其中,某些内存区域在虚拟机启动时即创建并持续存在,而另一些则随用户线程的生命周期动态创建和销毁。例如,每个线程都拥有一个独立的程序计数器,确保线程切换后能够准确恢复到之前的执行位置。这种设计不仅提高了多线程环境下的执行效率,还增强了系统的稳定性和可靠性。 ... [详细]
  • Nginx 反向代理配置与应用指南
    本文详细介绍了 Nginx 反向代理的配置与应用方法。首先,用户可以从官方下载页面(http://nginx.org/en/download.html)获取最新稳定版 Nginx,推荐使用 1.14.2 版本。下载并解压后,通过双击 `nginx.exe` 文件启动 Nginx 服务。文章进一步探讨了反向代理的基本原理及其在实际应用场景中的配置技巧,包括负载均衡、缓存管理和安全设置等,为用户提供了一套全面的实践指南。 ... [详细]
  • POJ 2482 星空中的星星:利用线段树与扫描线算法解决
    在《POJ 2482 星空中的星星》问题中,通过运用线段树和扫描线算法,可以高效地解决星星在窗口内的计数问题。该方法不仅能够快速处理大规模数据,还能确保时间复杂度的最优性,适用于各种复杂的星空模拟场景。 ... [详细]
  • 本指南详细介绍了如何在CentOS 6.6 64位系统上以root用户身份部署Tomcat 8服务器。系统环境为CentOS 6.6 64位,采用源码安装方式。所需软件为apache-tomcat-8.0.23.tar.gz,建议将软件下载至/root/opt目录。具体下载地址请参见官方资源。本指南涵盖了从环境准备到服务启动的完整步骤,适用于需要在该系统环境下搭建高性能Web应用服务器的技术人员。 ... [详细]
  • 该问题可能由守护进程配置不当引起,例如未识别的JVM选项或内存分配不足。建议检查并调整JVM参数,确保为对象堆预留足够的内存空间(至少1572864KB)。此外,还可以优化应用程序的内存使用,减少不必要的内存消耗。 ... [详细]
  • 本指南介绍了 `requests` 库的基本使用方法,详细解释了其七个主要函数。其中,`requests.request()` 是构建请求的基础方法,支持其他高级功能的实现。此外,我们还重点介绍了如何使用 `requests.get()` 方法来获取 HTML 网页内容,这是进行网页数据抓取和解析的重要步骤。通过这些基础方法,读者可以轻松上手并掌握网页数据抓取的核心技巧。 ... [详细]
  • 在数字图像处理中,Photoshop 的直方图是一个重要的工具,它能够精确地反映图像中不同亮度级别的分布情况。通过分析直方图,用户可以深入了解图像的曝光、对比度和色调范围,从而进行更精细的调整。直方图不仅模拟了物体表面反射光线的原理,还能帮助摄影师和设计师更好地掌握图像的明暗细节,优化视觉效果。 ... [详细]
  • 本文深入探讨了Java多线程环境下的同步机制及其应用,重点介绍了`synchronized`关键字的使用方法和原理。`synchronized`关键字主要用于确保多个线程在访问共享资源时的互斥性和原子性。通过具体示例,如在一个类中使用`synchronized`修饰方法,展示了如何实现线程安全的代码块。此外,文章还讨论了`ReentrantLock`等其他同步工具的优缺点,并提供了实际应用场景中的最佳实践。 ... [详细]
author-avatar
用户k3fe6y3kps
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有