数据库编程就是针对数据库的操作,通过编写程序的方式,让程序做为数据库的客户端进行数据库操作。

通过使用程序代码的方式去连接数据库服务器,通过和服务器进行交互完成对数据库的增删改查的方式,就称为数据库编程。

从图中可以看出,在 Python 中操作数据库,要经过五个步骤,分别是连接数据库,获取游标,数据库操作,关闭游标,关闭数据库连接。

在 Pyhton 中,使用 Pymysql 模块来对数据库进行编程。

1.1pymysql 操作

1. 导入模块

from pymysql import connect

2. Connection 对象

目的:用于建立代码与数据库的连接

3. 创建连接对象 conn=connect(参数列表)
  • 参数host:连接的mysql主机,如果本机是‘localhost’
  • 参数port:连接的mysql主机的端口,默认是3306
  • 参数database:数据库的名称
  • 参数user:连接的用户名
  • 参数password:连接的密码
  • 参数charset:通信采用的编码方式,推荐使用utf8
4. 关闭连接 conn.close()
5. 提交数据 conn.commit()
6. 撤销数据 conn.rollback()
7. 通过连接获取游标 cur = conn.cursor()返回Cursor对象

用于执行sql语句并获得结果

8. Cursor游标对象 目的: 执行sql语句
9. 获取Cursor对象 cur = conn.cursor()
10. 使用游标执行SQL语句 cur.execute(operation , [parameters])
11. 执行SQL语句,返回受影响的行数,主要用于执行insert、update、delete语句
12. 获取结果集中的一条 cur.fetchone() 返回一个元组
13. 获取结果集中的一条 cur.fetchmany(2) 返回一个元组 ,元组中包含两条数据
14. 获取结果集中的所有 cur.fetchall() 执行查询时,获取结果集的所有行,一行构成一个元组,再将这些元组装入一个元组返回.
15. 关闭游标 cur.close()

1.2 示例代码

在这里默认已经拥有了一个名为python_db的数据库,数据库包含students,classes两个数据表,students字段包括id, name, age, height, gender, cls_id, is_delect, classes字段包括id, name.

1.2.1 查询数据

# 导入pymysql模块
from pymysql import *# 与数据库建立连接
conn = connect(host = 'localhost', port = 3306, database = 'python_db', user = 'root', password = '', charset = 'utf8')# 通过连接获取游标
cur = conn.cursor()# 编辑mysql命令串
sql_str = '''select * from students;'''# 通过游标向数据库服务器发送命令
cur.execute(sql_str)# 接收数据库服务器返回的数据
result = cur.fetchall()# 循环输出数据信息
for t in result:print(t)# 关闭游标
cur.close()# 关闭数据库连接
conn.close()

1.2.2 增删改操作

# 导入pymysql模块
from pymysql import *# 建立连接
conn = connect(host = 'localhost', port = 3306, database = 'students', user = 'root', password = '', charset = 'utf8')# 通过连接获取游标
cur = conn.cursor()# 增加命令串:
sql_str = '''insert into students values (0, '新来的', 20, 180, '男', 1, 1);'''# 修改命令串:
#sql_str = '''update students set name = '小明' where name = '新来的';'''# 删除命令串:
#sql_str = '''delete from students where name = '小明';'''# 通过游标向数据库服务器发送命令
row_count = cur.execute(sql_str)# 在执行增删改数据库操作时需要对操作进行提交,否则不成功
conn.commit()# 关闭游标
cur.close()# 关闭连接
conn.close()

1.2.3 回滚(取消操作)

# 导入pymysql模块
from pymysql import *# 与mysql数据库建立连接
conn = connect(host = 'localhost', port = 3306, database = 'python_db', user = 'root', password = '', charset = 'utf8')# 通过连接获取游标
cur = conn.cursor()# 创建sql命令串
sql_str = '''insert into students values (0, '小华',  20, 180, '男', 1, 1);'''# 插入10条相同的数据
for i in range(10):# 执行sql语句row_count = cur.execute(sql_str)# 在执行增删改操作时,如果不想提交前面的修改操作,可以使用 rollback 回滚取消操作
conn.rollback()# 关闭游标
cur.close()# 关闭数据库连接
cur.close()

1.3 参数化列表防止SQL注入

SQL注入:

产生原因: 后台对用户提交的带有恶意的数据和 SQL 进行字符串方式的拼接,得到了脱离原意的 SQL 语句,从而影响了 SQL 语句的语义,最终产生数据泄露的现象。

如何防止: SQL 语句的参数化, 将 SQL 语句的所有数据参数存在一个列表\元组\字典中传递给 execute 函数的第二个参数。

注意:

  • 此处不同于python的字符串格式化,必须全部使用%s占位.
# 导入模块
from pymysql import *# 与mysql数据库建立连接
conn = connect(host = 'localhost', port = 3306, database = 'python_db', user = 'root', password = '', charset = 'utf8')# 获取游标
cur = conn.cursor()# 接收外部传入的查询指令条件
find_name = input('输入要查询的姓名:')# 创建sql命令
sql_str = '''select * from student from name = %s'''% find_name# 执行select语句,execute方法在内部实现了防SQL注入的功能,但具体如何实现并不清楚,隐藏了细节
# 这里使用了元组的方式将find_name 传入sql_str中
row_count = cur.execute(sql_str, (find_name, ))# 注意:
# 如果要是有多个参数,需要进行参数化
# 那么(sql_str, (数值1, 数值2....)),此时sql语句中有多个%s即可
# 打印受影响的行数
print(row_count)# 获取查询的结果
result = cur.fetchall()# 打印查询的结果
print(result)# 关闭游标
cur.close()# 关闭数据库连接
conn.close()

Python数据库编程相关推荐

  1. python数据库编程(1):潦草的开篇

    一.前言 关于数据库编程,涉及知识点广而杂,所以我并非一遍就能掌握,这里汲取了我的实践和认识,算是对python数据库编程的做一个铺垫吧.在以后的学习过程中会不断地完善数据库编程的知识点,鉴于此,另当 ...

  2. Python数据库编程pymysql

    Python数据库编程pymysql 一.数据库编程介绍 数据库编程就是针对数据库的操作,通过编写程序的方式,让程序做为数据库的客户端进行数据库操作. 对于MySQL的操作我们可以通过SQL语句,但是 ...

  3. Python数据库编程之索引

    文章目录 实验要求 一.SQL创建学生表 1.1 creat table 1.2 show index 二.ORM方式创建数据 2.1 建立数据 2.2 查询数据 总结 实验要求 实验目的:是为了理解 ...

  4. python数据库编程 代码 源码_Python可以这样学_Python教程

    资源名称:Python可以这样学 内容简介: 全书共分16章,对Python内部工作原理进行了一定深度的剖析,99%以上的案例代码使用Python 3.5.1实现,也适用于Python 3.4.x(除 ...

  5. python数据库编程dbf_python读写dbf文件

    下面是编程之家 jb51.cc 通过网络收集整理的代码片段. 编程之家小编现在分享给大家,也给大家做个参考. 读取遍历dBASE或Xbase文件中的记录.从Python的序列创建DBF文件. impo ...

  6. 【Python】python数据库编程

    在任何的应用程序中,都需要持久存储.一般说来,有三种基本的存储机制:文件.关系型数据库或其它的一些变种,例如现有系统的API.ORM.文件管理器.电子表格.配置文件等等. 通过python访问数据库, ...

  7. python 数据库编程,这篇是针对 mysql 的,滚雪球学Python第4季第13篇

    在第一季滚雪球学 python 中,我们已经接触了 python 操作 sqlite,本篇博客为你介绍 python 与 mysql 和 nosql 之间的故事. 在正式学习之前,先确保你电脑上已经安 ...

  8. python数据库编程:Python基于Pymssql模块实现连接SQL Server数据库的方法详解

    本文实例讲述了Python基于Pymssql模块实现连接SQL Server数据库的方法.分享给大家供大家参考,具体如下: 数据库版本:SQL Server 2012. 按照Python版本来选择下载 ...

  9. python数据库编程dbf_如何使用Python dbf库读取和创建新的foxpro2.6数据库表

    库版本:dbf 0.97.0,python版本3.5.5 我试图用dbf库创建一个新的foxpro2.6.DBF文件.我跑>>> import dbf >>> ta ...

  10. python数据库mysql_python数据库(mysql)操作

    一.软件环境 python环境默认安装了sqlite3,如果需要使用sqlite3我们直接可以在python代码模块的顶部使用import sqlite3来导入该模块.本篇文章我是记录了python操 ...

最新文章

  1. Nokia House”或“NoHo
  2. boost::callable_traits的remove_member_const_t的测试程序
  3. 详解C++中的函数调用和下标以及成员访问运算符的重载
  4. c++中recvfrom函数_通俗易懂:快速理解网络编程中5种IO模型
  5. 以太坊源码(03):POA委员会选举机制
  6. 机房计算机配置思维导图,运用思维导图培养高中学生信息技术学科核心素养
  7. Excel获取目标时间点/日期的方法
  8. 大学计算机课能旷课吗,计算机课旷课检讨书
  9. FPGA控制TDC-GPX2时间间隔测量(三)
  10. 从零开始学USB(二十四、USB接口HID类设备(六)_物理描述符)
  11. 常用生物信息 ID 及转换方法
  12. 真机运行、手机运行、真机联调常见问题
  13. 计算机显示没有可以的ip地址,w7电脑提示没有有效ip地址怎么处理
  14. 华为WLAN基础全套学习笔记整理
  15. 卷积神经网络中feature map是什么
  16. 阿里OCR扫描字识别demo
  17. 专访阿里云闵万里:云上逐鹿,ET大脑要做行业化、垂直化的创新运用
  18. 使用SaveFileDialog将DataTable文件保存成csv文件
  19. 施工图审制度全面取消:图审单位退场,整顿建筑设计行业乱象
  20. 第四章 流程控制与数组

热门文章

  1. 在线问卷工具LimeSurvey
  2. 通信系统仿真原理与无线应用笔记-MATLAB
  3. 为大家带来的是C语言入门视频教程
  4. c++ primer plus第六版复习题及答案
  5. FastStone Capture:Windows系统下小巧好用的宝藏电脑截图软件
  6. 充值150日赚1000多,一篇AI打扑克的论文竟登上科学杂志
  7. 记七彩虹刷bios问题
  8. 怀念WAP网站和让IE浏览器支持WAP网站
  9. 重庆兴渝计算机培训中心,重庆兴渝职业中等专业学校2021招生录取分数线
  10. 泛微协同商务系统_泛微ecology OA Beanshell组件远程代码执行漏洞复现