Python学习系列(七)( 数据库编程)
一,MySQL-Python插件
Python里操作MySQL数据库,需要Python下安装访问MySQL数据库接口API包即插件,从而使得Python2.7能访问操作MySQL数据库。MySQL软件可以去官网下载:http://www.mysql.com/; MySQLdb插件下载:http://sourceforge.net/projects/mysql-python/files/latest/download
二,访问MySQL数据库
1,连接数据库mysql
基本格式:connect ([host=]'ip',[user=]'user',[passwd=]'password',[db=]'dbname')
2,数据库的基本操作
1)create创建表

1 import MySQLdb 2 #connect to a database 'test' 3 conn=MySQLdb.connect(host='localhost',user='root',passwd='zbc123',db='test') 4 cursor=conn.cursor() 5 #create a table 6 cursor.execute('create table \ 7 test(ID int primary key auto_increment,Name char(25))') 8 #Closing database 9 cursor.close() 10 conn.close()
2)fetchall访问:

1 import MySQLdb 2 #connect to a database 'test' 3 conn=MySQLdb.connect(host='localhost',user='root',passwd='zbc123',db='test') 4 cursor=conn.cursor() 5 #fetch datas 6 n=cursor.execute('select * from test;') 7 r=cursor.fetchall() 8 print n,r 9 #Closing database 10 cursor.close() 11 conn.close() 12 13 >>> ================================ RESTART ================================ 14 >>> 15 3 ((4L, 'zhangbc'), (5L, 'lis08'), (6L, 'wangw')) 16 >>>
在Mysql5.6环境下运行:
3)insert向表中插入数据:

1 import MySQLdb 2 #connect to a database 'test' 3 conn=MySQLdb.connect(host='localhost',user='root',passwd='zbc123',db='test') 4 cursor=conn.cursor() 5 #insert data into table 'test' 6 mysql='''insert into test(id,sname) values(4,'zhanghua')''' 7 cursor.execute(mysql) 8 conn.commit()#below mysql5.0 needed 9 #fetch datas 10 n=cursor.execute('select * from test;') 11 r=cursor.fetchall() 12 print n,r 13 #Closing database 14 cursor.close() 15 conn.close() 16 17 >>> ================================ RESTART ================================ 18 >>> 19 4 ((1L, 'zhangbc'), (2L, 'lis'), (3L, 'wangw'), (4L, 'zhanghua'))
注意:一定要写上conn.commit();事物不提交,将回滚。比较:
4)update修改表中数据:

1 import MySQLdb 2 #connect to a database 'test' 3 conn=MySQLdb.connect(host='localhost',user='root',passwd='zbc123',db='test') 4 cursor=conn.cursor() 5 #update data of the table 'test' 6 mysql='''update test set sname='Lisi08' where id=2''' 7 cursor.execute(mysql) 8 conn.commit()#below mysql5.0 needed 9 #fetch datas 10 n=cursor.execute('select * from test;') 11 r=cursor.fetchall() 12 print n,r 13 #Closing database 14 cursor.close() 15 conn.close() 16 17 >>> ================================ RESTART ================================ 18 >>> 19 4 ((1L, 'zhangbc'), (2L, 'Lisi08'), (3L, 'wangw'), (4L, 'zhanghua'))
5)delete删除表中数据:

1 import MySQLdb 2 #connect to a database 'test' 3 conn=MySQLdb.connect(host='localhost',user='root',passwd='zbc123',db='test') 4 cursor=conn.cursor() 5 #delete data of the table 'test' 6 mysql='''delete from test where id=4''' 7 cursor.execute(mysql) 8 conn.commit()#below mysql5.0 needed 9 #fetch datas 10 n=cursor.execute('select * from test;') 11 r=cursor.fetchall() 12 print n,r 13 #Closing database 14 cursor.close() 15 conn.close() 16 17 >>> ================================ RESTART ================================ 18 >>> 19 3 ((1L, 'zhangbc'), (2L, 'Lisi08'), (3L, 'wangw'))
6)关于select及其遍历:
i)使用元组tuple与fetchone结合

1 import MySQLdb 2 #connect to a database 'test' 3 conn=MySQLdb.connect(host='localhost',user='root',passwd='zbc123',db='test') 4 cursor=conn.cursor() 5 #fetch datas 6 cursor.execute('select * from test;') 7 #获得结果集的记录 8 numrows=int(cursor.rowcount) 9 #循环,取行数据 10 for i in range(numrows): 11 row=cursor.fetchone() 12 print row[0],row[1] 13 #Closing database 14 cursor.close() 15 conn.close() 16 17 >>> ================================ RESTART ================================ 18 >>> 19 4 zhangbc 20 5 lis08 21 6 wangw
ii)使用字典cursor

1 #-*- coding:UTF-8 -*- 2 import MySQLdb as mdb 3 #connect to a database 'test' 4 conn=mdb.connect(host='localhost',user='root',passwd='zbc123',db='test') 5 with conn: 6 #获取连接上的字典cursor,每一个cursor其实都是cursor的子类 7 cur=conn.cursor(mdb.cursors.DictCursor) 8 #fetch datas 9 cur.execute('select * from test;') 10 #获得结果集 11 rows=cur.fetchall() 12 #循环,取行数据 13 for row in rows: 14 print '%s %s'%(row['ID'],row['Name']) 15 #Closing database 16 cur.close() 17 conn.close() 18 19 >>> ================================ RESTART ================================ 20 >>> 21 4 zhangbc 22 5 lis08 23 6 wangw
iii)获取单个表的字段名及其信息

1 #-*- coding:UTF-8 -*- 2 import MySQLdb as mdb 3 #connect to a database 'test' 4 conn=mdb.connect(host='localhost',user='root',passwd='zbc123',db='test') 5 with conn: 6 #获取连接上的字典cursor,每一个cursor其实都是cursor的子类 7 cur=conn.cursor() 8 #fetch datas 9 cur.execute('select * from test;') 10 #获得结果集 11 rows=cur.fetchall() 12 #获得链接对象的描述信息 13 desc=cur.description 14 print 'cur.description:',desc 15 #打印表头 16 print '%2s %3s'%(desc[0][0],desc[1][0]) 17 #循环,取行数据 18 for row in rows: 19 print '%2s %3s'%row 20 #Closing database 21 cur.close() 22 conn.close() 23 24 >>> ================================ RESTART ================================ 25 >>> 26 cur.description: (('ID', 3, 1, 11, 11, 0, 0), ('Name', 254, 7, 25, 25, 0, 1)) 27 ID Name 28 4 zhangbc 29 5 lis08 30 6 wangw
三,小结
本文主要介绍了Python下如何访问并操数据库的基本知识,如:如何连接数据库,如何执行执行SQL语句等等。
作者: 天堂的鸽子
出处:https://www.cnblogs.com/zhangbc/p/3920589.html
版权:本文采用「署名-非商业性使用-相同方式共享 4.0 国际」知识共享许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述