python mysql实例_Python使用MySQL数据库的方法以及一个实例

使用环境:Windows+python3.4+MySQL5.5+Navicat

一、创建连接

1.准备工作,想要使用Python操作MySQL,首先需要安装MySQL-Python的包,在Python 3.x下,该包已经改名为MySQLClient。可以使用pip方式安装:

pip install MySQLClient

或者下载包文件,进行安装也可以。

2.Python使用MySQL的流程:

aecea4997552ef7703c103e488646e10.png

3.启动MySQL服务器:以管理员身份启动“cmd”,输入命令:’net start mysql‘

Python中使用MySQL导入方法:import MySQLdb

4.创建Connection

Connection:创建了Python客户端与数据库之间的网络通路。他的参数如下

参数名

类型

说明

host

String

MySQL的服务器地址

port

int

MySQL的端口号

user

String

用户名

passwd

String

密码

db

String

使用的数据库

charset

String

连接字符集

Connection支持的方法:

方法名

说明

cursor()

创建并且返回游标

commit()

提交当前事物

rollback()

回滚当前事物r()

close()

关闭Connection

5.获取Cursor.

Cursor:游标对象,用于执行查询和获取结果,它支持的方法如下:

方法名

说明

execute()

用于执行一个数据库的查询命令

fetchone()

获取结果集中的下一行

fetchmany(size)

获取结果集中的下(size)行

fetchall()

获取结果集中剩下的所有行

rowcount

最近一次execute返回数据/影响的行数

close()

关闭游标

下面我们在Python中创建一个实例:

48304ba5e6f9fe08f3fa1abda7d326ab.png

import MySQLdb

conn=MySQLdb.connect(host='127.0.0.1',port=3306,user='root',passwd='199331',db='test',charset='utf8')

cursor=conn.cursor()

print(conn)

print(cursor)

cursor.close()

conn.close()

48304ba5e6f9fe08f3fa1abda7d326ab.png

运行程序结果如下:

9f121f6229d5be6231f6ddb35c368d7f.png

从结果中我们可以看见成功创建了一个Connection和Cursor对象。

二、建立数据库,进行一些简单操作

1.简单的创建一个’user‘表,并且插入一些数据。user表中只有两个字段:userid和username。代码如下:

48304ba5e6f9fe08f3fa1abda7d326ab.png

import MySQLdb

conn=MySQLdb.connect(host='127.0.0.1',port=3306,user='root',passwd='199331',db='test',charset='utf8')

cur=conn.cursor()

cur.execute("""

create table if not EXISTS user

(

userid int(11) PRIMARY KEY ,

username VARCHAR(20)

)

""")

for i in range(1,10):

cur.execute("insert into user(userid,username) values('%d','%s')" %(int(i),'name'+str(i)))

conn.commit()

cur.close()

conn.close()

48304ba5e6f9fe08f3fa1abda7d326ab.png

我们用Navicat打开数据库,查看一下结果,

bQ1Xn1yZ2xsAAAAASUVORK5CYII=,可以看到成功创建表,并且插入了十个数据。

2.我们操作一下Cursor里面的一些方法。

execute()方法:执行SQL,将一个结果从数据库获取到客户端

fetch*()方法:移动rownumber,返回数据。

例如我们有如下代码:

rs=cursor.fetchall()print(rs)

结果如下:

BwDtiN4YwRSoAAAAAElFTkSuQmCC

我们可以看出执行查询全部数据后,rowcount为10

执行fetchone()方法后返回一个数据,执行fetchmany(3)后返回3条数据,执行fetchall()后返回剩下的所有数据。

再有如下代码:

此时的执行结果为:

wFxUGBzFsG0mQAAAABJRU5ErkJggg==

3.上面介绍的便是数据库中常说的Select操作,下面我们介绍数据的更新,即:insert、update、delete操作。值得注意的是在这部分操作时需要注意的是是否数据发生异常,如果数据没有发生异常,我们便可以直接使用commit()进行提交(注:如没有使用commit,则数据库不会发生任何变化)。但是如果出现了异常,那么久需要使用rollback()进行回滚。

3.1先来看一个没有异常,正常提交的例子:

conn.commit()

上面的操作即是:添加一条(10,’name10‘)的数据、将userid=9的username修改为’name91‘,删除userid=3的数据,执行上面代码后我们来用Navicat查看一下数据:

Am21v0AFhd5VAAAAAElFTkSuQmCC从结果可以看到代码执行正常。

3.2.再来看一个有异常的数据

这里的insert和update操作一样,只不过把delete里面的userid字段错误的写成了useri,执行代码:

9PS3rD1r7b+533Znwxfg87wAJCL7AEhE9gGQiOwDIBHZB0Aisg+ARGQfAInIPgASkX0AJCL7AEhE9gGQ6P87x2OdwLn7hgAAAABJRU5ErkJggg==

可以看到显示出异常,这时我们来看一下数据库数据:

upjropwJQF3BYsBfdTmmuiiHdlNXsBigCwe6aAFdOKa6KGcCUFewGKALx1QX5dBu6goWA3ThQBctoAvHVBfMBGgbRrqYvBi0DegCcgBdQA6gC8gBdAE5gC4gB9AF5AC6gBxAF5AD6AJyAF1ADqALyAF0ATn4P1qUrP92RY28AAAAAElFTkSuQmCC数据没有任何改变。这就是rollback()的作用

因此,我们以后再写增删改查操作时,最好把操作放入一个try控制块中,来避免一些不必要的错误。

下面是一个银行转账的实例:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值