Python操作MySQL基本环境搭建及增删改查实现

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:


写作原因:这篇文章将带领读者使用Python操作MySQL数据库。在PHP和Python之间博主更倾向于Python,而后台开发免不了要操作数据库,所以就有了这篇文章。

安装Python

鉴于上一篇关于Python的文章已经有关于Python安装的介绍了,这里就不花笔墨多说了。

安装MySQL

MySQL介绍

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于Oracle旗下产品。MySQL是一款优秀的开源产品,正是由于其开源性使其逐渐成为现今商业数据库的主流选择之一。

具体安装流程(Win版)

由于博主目前只在Win平台测试,所以这里只介绍Win版的安装流程。

首先下载mysql-5.6.33-winx64( 下载地址 ),mysql5.7以上版本在安装的过程中会出现一些问题,所以本人选择了5.6版本。安装的过程一直下一步就行;

然后配置系统环境变量。找到“系统-高级系统设置-环境变量”,在Path的最后加上数据库内的bin文件夹目录如“;D:\mysql-5.6.33-winx64\bin”(注意一定要加分号);

到根目录下打开my-default.ini文件,将“# basedir = …… # datadir = ……”修改为“basedir = D:\mysql-5.6.33-winx64 datadir = D:\mysql-5.6.33-winx64\data”;

打开cmd(一定要管理员权限!)转到“D:\mysql-5.6.33-winx64\bin”目录,输入“mysqld -install”。等到出现“Service successfully installed.”之后就继续输入“net start mysql”。这样mysql就启动了。

使用pymysql包

下面就是正是使用Python来操作mysql的第一步了。打开cmd,直接输入pip install PyMySql,等它安装完毕就OK了,就是这么简单。

利用Mysql WorkBench可视化数据库

对于数据库,如果用命令行的话有时可能会比较麻烦,这时可以考虑使用GUI界面代替CLI。官方提供了MySql WorkBench( 点击下载 )。使用WorkBench我们可以轻易地查看本地数据库的一些状态、数据库的操作等等,具体使用不多说了,这里只说一下新建数据库和数据表。点击图标栏第四个图标(create a new schema in the connected server),设置好相关参数就可以创建数据库。在Schema工具栏中,选择你要添加表的数据库,右键Tables选择“Create Table”,写好字段和数据类型,即可完成数据表的创建。

实现基本的数据库的增删改查

下面开始写代码。

具体代码如下:

 

import pymysql
def connDB():
#连接数据库
conn=pymysql.connect(host='localhost',user='root',passwd='',db='first')
cur=conn.cursor()
return (conn,cur)
def exeUpdate(conn,cur,sql):
#更新语句,可执行UpdateInsert语句
sta=cur.execute(sql)
conn.commit()
return (sta)
def exeDelete(conn,cur,IDs):
#删除语句,可批量删除
for eachID in IDs.split(' '):
sta=cur.execute('delete from students where Id=%d'%int(eachID))
conn.commit()
return (sta)
def exeQuery(cur,sql): 
 #查询语句 
 cur.execute(sql)
result = cur.fetchone()
return (result)
def connClose(conn,cur):
#关闭所有连接
cur.close()
conn.close()
conn = connDB()[0]
cur = connDB()[1]
exeUpdate(conn,cur,"INSERT INTO first_note (idfirst_note, note_title , note_content ) VALUES (0,'Title','This is the content');")
print(exeQuery(cur,"SELECT note_title ,note_content FROM first_note;"))
connClose() 

这里有几个地方说明一下:

创建:

我们通过conn=pymysql.connect(host='localhost',user='root',passwd='',db='first') 方法获取一个connection对象。

connection对象类似于数据操作过程中的管道,我们数据操作都是在connection之上进行的。(有过网络编程经验的朋友一下就理解了),然后再通过 cur=conn.cursor() 获取游标,游标对象则类似于管道中的载体,进行数据的传送。有了cur我们才能直接操作数据库。

增删查改:代码中我们把增删查改分成四个函数,事实上这四个操作都是调用cur.execute()进行的,也就是直接使用SQL语言进行数据库操作。如果有必要我们应该对它们再次封装便于使用。具体代码看上面。

关闭:最后我们使用 cur.close() conn.close() 分别关闭游标和connection对象,这样就结束了一次数据操作。

总结

这篇文章搭建的是win平台下的本地数据库,关于Linux平台的及远程数据库的相关操作类似。此外环境配完了更重要的是学习掌握SQL语言和最大程度运用Python写出优秀的代码。就这样啦~


作者:佚名

来源:51CTO

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
21天前
|
缓存 NoSQL 关系型数据库
在Python Web开发过程中:数据库与缓存,MySQL和NoSQL数据库的主要差异是什么?
MySQL是关系型DB,依赖预定义的表格结构,适合结构化数据和复杂查询,但扩展性有限。NoSQL提供灵活的非结构化数据存储(如JSON),无统一查询语言,但能横向扩展,适用于大规模、高并发场景。选择取决于应用需求和扩展策略。
111 1
|
28天前
|
数据格式 Python
如何使用Python的Pandas库进行数据透视图(melt/cast)操作?
Pandas的`melt()`和`pivot()`函数用于数据透视。基本步骤:导入pandas,创建DataFrame,然后使用这两个函数转换数据格式。示例代码展示了如何通过`melt()`转为长格式,再用`pivot()`恢复为宽格式。输入数据是包含'Name'和'Age'列的DataFrame,最终结果经过转换后呈现出不同的布局。
39 6
|
30天前
|
XML 关系型数据库 MySQL
python将word(doc或docx)的内容导入mysql数据库
用python先把doc文件转换成docx文件(这一步也可以不要后续会说明),然后读取docx的文件并另存为htm格式的文件(上一步可以直接把doc文件另存为htm),python根据bs4获取p标签里的内容,如果段落中有图片则保存图片。(图片在word文档中的位置可以很好的还原到生成的数据库内容) 我见网上有把docx压缩后解压获取图片的,然后根据在根据xml来读取图片的位置,我觉得比较繁琐。用docx模块读取段落的时候还需要是不是判断段落中有分页等,然而转成htm之后就不用判断那么多直接判断段落里的样式或者图片等就可以了。
21 1
|
1月前
|
索引 Python
如何使用Python的Pandas库进行数据透视表(pivot table)操作?
如何使用Python的Pandas库进行数据透视表(pivot table)操作?
16 0
|
1月前
|
Unix Shell Linux
赞!优雅的Python多环境管理神器!易上手易操作!
赞!优雅的Python多环境管理神器!易上手易操作!
|
16天前
|
存储 SQL 关系型数据库
【MySQL】4. 表的操作
【MySQL】4. 表的操作
19 0
|
30天前
|
SQL 关系型数据库 MySQL
|
11天前
|
人工智能 机器人 C++
【C++/Python】Windows用Swig实现C++调用Python(史上最简单详细,80岁看了都会操作)
【C++/Python】Windows用Swig实现C++调用Python(史上最简单详细,80岁看了都会操作)
|
15天前
|
缓存 关系型数据库 MySQL
MySQL查询优化:提速查询效率的13大秘籍(合理使用索引合并、优化配置参数、使用分区优化性能、避免不必要的排序和group by操作)(下)
MySQL查询优化:提速查询效率的13大秘籍(合理使用索引合并、优化配置参数、使用分区优化性能、避免不必要的排序和group by操作)(下)
|
30天前
|
SQL 关系型数据库 MySQL
python在mysql中插入或者更新null空值
这段代码是Python操作MySQL数据库的示例。它执行SQL查询从表`a_kuakao_school`中选取`id`,`university_id`和`grade`,当`university_id`大于0时按升序排列。然后遍历结果,根据`row[4]`的值决定`grade`是否为`NULL`。若不为空,`grade`被格式化为字符串;否则,设为`NULL`。接着构造UPDATE语句更新`university`表中对应`id`的`grade`值,并提交事务。重要的是,字符串`NULL`不应加引号,否则更新会失败。
19 2