python操作mysql数据库
发布时间 - 2026-01-10 23:26:47 点击率:次一、数据库基本操作

1. 想允许在数据库写中文,可在创建数据库时用下面命令
create database zcl charset utf8;
2. 查看students表结构
desc students;
3. 查看创建students表结构的语句
show create table students;
4. 删除数据库
drop database zcl;
5. 创建一个新的字段
alter table students add column nal char(64);
PS: 本人是很讨厌上面这种“简单解释+代码”的博客。其实我当时在mysql终端写了很多的实例,不过因为当时电脑运行一个看视频的软件,导致我无法Ctrl+C/V。现在懒了哈哈~~
二、python连接数据库
python3不再支持mysqldb。其替代模块是PyMySQL。本文的例子是在python3.4环境。
1. 安装pymysql模块
pip3 install pymysql
2. 连接数据库,插入数据实例
import pymysql
#生成实例,连接数据库zcl
conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
#生成游标,当前实例所处状态
cur = conn.cursor()
#插入数据
reCount = cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)',('Jack','man',25,1351234,"CN"))
reCount = cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)',('Mary','female',18,1341234,"USA"))
conn.commit() #实例提交命令
cur.close()
conn.close()
print(reCount)
查看结果:
mysql> select* from students; +----+------+-----+-----+-------------+------+ | id | name | sex | age | tel | nal | +----+------+-----+-----+-------------+------+ | 1 | zcl | man | 22 | 15622341234 | NULL | | 2 | alex | man | 30 | 15622341235 | NULL | +----+------+-----+-----+-------------+------+ rows in set
3. 获取数据
import pymysql
conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
cur = conn.cursor()
reCount = cur.execute('select* from students')
res = cur.fetchone() #获取一条数据
res2 = cur.fetchmany(3) #获取3条数据
res3 = cur.fetchall() #获取所有(元组格式)
print(res)
print(res2)
print(res3)
conn.commit()
cur.close()
conn.close()
输出:
(1, 'zcl', 'man', 22, '15622341234', None) ((2, 'alex', 'man', 30, '15622341235', None), (5, 'Jack', 'man', 25, '1351234', 'CN'), (6, 'Mary', 'female', 18, '1341234', 'USA')) ()
三、事务回滚
事务回滚是在数据写到数据库前执行的,因此事务回滚conn.rollback()要在实例提交命令conn.commit()之前。只要数据未提交就可以回滚,但回滚后ID却是自增的。请看下面的例子:
插入3条数据(注意事务回滚):
import pymysql
#连接数据库zcl
conn=pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
#生成游标,当前实例所处状态
cur=conn.cursor()
#插入数据
reCount=cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)', ('Jack', 'man', 25, 1351234, "CN"))
reCount=cur.execute('insert into students(name, sex, age, tel, nal) values(%s,%s,%s,%s,%s)', ('Jack2', 'man', 25, 1351234, "CN"))
reCount=cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)', ('Mary', 'female', 18, 1341234, "USA"))
conn.rollback() #事务回滚
conn.commit() #实例提交命令
cur.close()
conn.close()
print(reCount)
未执行命令前与执行命令后(包含回滚操作)(注意ID号): 未执行上面代码与执行上面代码的结果是一样的!!因为事务已经回滚,故students表不会增加数据!
mysql> select* from students; +----+------+--------+-----+-------------+------+ | id | name | sex | age | tel | nal | +----+------+--------+-----+-------------+------+ | 1 | zcl | man | 22 | 15622341234 | NULL | | 2 | alex | man | 30 | 15622341235 | NULL | | 5 | Jack | man | 25 | 1351234 | CN | | 6 | Mary | female | 18 | 1341234 | USA | +----+------+--------+-----+-------------+------+ rows in set
执行命令后(不包含回滚操作):只需将上面第11行代码注释。
mysql> select* from students; +----+-------+--------+-----+-------------+------+ | id | name | sex | age | tel | nal | +----+-------+--------+-----+-------------+------+ | 1 | zcl | man | 22 | 15622341234 | NULL | | 2 | alex | man | 30 | 15622341235 | NULL | | 5 | Jack | man | 25 | 1351234 | CN | | 6 | Mary | female | 18 | 1341234 | USA | | 10 | Jack | man | 25 | 1351234 | CN | | 11 | Jack2 | man | 25 | 1351234 | CN | | 12 | Mary | female | 18 | 1341234 | USA | +----+-------+--------+-----+-------------+------+ rows in set
总结:虽然事务回滚了,但ID还是自增了,不会因回滚而取消,但这不影响数据的一致性(底层的原理我不清楚~)
四、批量插入数据
import pymysql
#连接数据库zcl
conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
#生成游标,当前实例所处状态
cur = conn.cursor()
li = [
("cjy","man",18,1562234,"USA"),
("cjy2","man",18,1562235,"USA"),
("cjy3","man",18,1562235,"USA"),
("cjy4","man",18,1562235,"USA"),
("cjy5","man",18,1562235,"USA"),
]
#插入数据
reCount = cur.executemany('insert into students(name,sex,age,tel,nal) values(%s,%s,%s,%s,%s)', li)
#conn.rollback() #事务回滚
conn.commit() #实例提交命令
cur.close()
conn.close()
print(reCount)
pycharm下输出: 5
mysql终端显示:
mysql> select* from students; #插入数据前 +----+-------+--------+-----+-------------+------+ | id | name | sex | age | tel | nal | +----+-------+--------+-----+-------------+------+ | 1 | zcl | man | 22 | 15622341234 | NULL | | 2 | alex | man | 30 | 15622341235 | NULL | | 5 | Jack | man | 25 | 1351234 | CN | | 6 | Mary | female | 18 | 1341234 | USA | | 10 | Jack | man | 25 | 1351234 | CN | | 11 | Jack2 | man | 25 | 1351234 | CN | | 12 | Mary | female | 18 | 1341234 | USA | +----+-------+--------+-----+-------------+------+ rows in set mysql> mysql> select* from students; #插入数据后 +----+-------+--------+-----+-------------+------+ | id | name | sex | age | tel | nal | +----+-------+--------+-----+-------------+------+ | 1 | zcl | man | 22 | 15622341234 | NULL | | 2 | alex | man | 30 | 15622341235 | NULL | | 5 | Jack | man | 25 | 1351234 | CN | | 6 | Mary | female | 18 | 1341234 | USA | | 10 | Jack | man | 25 | 1351234 | CN | | 11 | Jack2 | man | 25 | 1351234 | CN | | 12 | Mary | female | 18 | 1341234 | USA | | 13 | cjy | man | 18 | 1562234 | USA | | 14 | cjy2 | man | 18 | 1562235 | USA | | 15 | cjy3 | man | 18 | 1562235 | USA | | 16 | cjy4 | man | 18 | 1562235 | USA | | 17 | cjy5 | man | 18 | 1562235 | USA | +----+-------+--------+-----+-------------+------+ rows in set
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# python
# mysql数据库
# 数据库操作
# python操作mysql数据库
# 使用Python对MySQL数据操作
# Windows下安装python MySQLdb遇到的问题及解决方法
# Python如何读取MySQL数据库表数据
# 让python 3支持mysqldb的解决方法
# python3使用PyMysql连接mysql数据库实例
# Linux下安装Python3和django并配置mysql作为django默认服务器方法
# Python版Mysql爆破小脚本
# Python实现Mysql数据库连接池实例详解
# 连接数据库
# 所处
# 是在
# 我不
# 却是
# 只需
# 要在
# 人是
# 可在
# 写了
# 写到
# 创建一个
# 时用
# 就可以
# 不包含
# 很讨厌
# 这不
# 我当时
# 是一样的
# 博客
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何用花生壳三步快速搭建专属网站?
活动邀请函制作网站有哪些,活动邀请函文案?
Android 常见的图片加载框架详细介绍
Laravel如何自定义分页视图?(Pagination示例)
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
WEB开发之注册页面验证码倒计时代码的实现
Laravel如何处理和验证JSON类型的数据库字段
在Oracle关闭情况下如何修改spfile的参数
如何在Ubuntu系统下快速搭建WordPress个人网站?
如何用景安虚拟主机手机版绑定域名建站?
如何用腾讯建站主机快速创建免费网站?
Laravel Seeder填充数据教程_Laravel模型工厂Factory使用
Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册
Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤
,交易猫的商品怎么发布到网站上去?
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
EditPlus中的正则表达式实战(5)
如何快速上传自定义模板至建站之星?
Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践
如何快速搭建高效服务器建站系统?
Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区
Python并发异常传播_错误处理解析【教程】
Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤
如何在IIS中配置站点IP、端口及主机头?
Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】
Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】
laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法
Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程
JS去除重复并统计数量的实现方法
如何使用 jQuery 正确渲染 Instagram 风格的标签列表
javascript中的数组方法有哪些_如何利用数组方法简化数据处理
php做exe能调用系统命令吗_执行cmd指令实现方式【详解】
如何快速搭建二级域名独立网站?
微信h5制作网站有哪些,免费微信H5页面制作工具?
javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】
如何快速生成可下载的建站源码工具?
如何快速配置高效服务器建站软件?
如何在云主机上快速搭建网站?
零基础网站服务器架设实战:轻量应用与域名解析配置指南
Laravel怎么防止CSRF攻击_Laravel CSRF保护中间件原理与实践
Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】
Laravel如何使用Livewire构建动态组件?(入门代码)
高端企业智能建站程序:SEO优化与响应式模板定制开发
HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】
Laravel如何实现API资源集合?(Resource Collection教程)
绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信
android nfc常用标签读取总结
如何快速使用云服务器搭建个人网站?
Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】

