http://www.cnblogs.com/woider/p/5926744.html

==================pymysql===================

转载的文章,尊重原创。我修改了部分错误的地方……

由于 MySQLdb 模块还不支持 Python3.6,所以 Python3.6 如果想连接MySQL,需要安装 pymysql 模块。

pymysql 模块可以通过 pip 安装。但如果你使用的是 pycharm IDE,则可以使用 project python 安装第三方模块。

[File] >> [settings] >> [Project: python] >> [Project Interpreter] >> [Install按钮]

由于Python统一了数据库连接的接口,所以 pymysql 和 MySQLdb 在使用方式上是类似的:

pymysql.Connect()参数说明
host(str):      MySQL服务器地址
port(int):      MySQL服务器端口号
user(str):      用户名
passwd(str):    密码
db(str):        数据库名称
charset(str):   连接编码

connection对象支持的方法
cursor()        使用该连接创建并返回游标
commit()        提交当前事务
rollback()      回滚当前事务
close()         关闭连接

cursor对象支持的方法
execute(op)     执行一个数据库的查询命令
fetchone()      取得结果集的下一行
fetchmany(size) 获取结果集的下几行
fetchall()      获取结果集中的所有行
rowcount()      返回数据条数或影响行数
close()         关闭游标对象

==================MySQL===================

首先在连接数据库之前,先创建一个交易表,方便测试 pymysql这个库

  CREATE TABLE trade(
  id int(4) unsigned NOT NULL AUTO_INCREMENT,
  name varchar(10) NOT NULL COMMENT '用户真实姓名',
  account varchar(10) NOT NULL COMMENT '银行储蓄账号',
  saving decimal(8,2) unsigned NOT NULL DEFAULT '0.00' COMMENT '账户储蓄金额',
  expend decimal(8,2) unsigned NOT NULL DEFAULT '0.00' COMMENT '账户支出总计',
  income decimal(8,2) unsigned NOT NULL DEFAULT '0.00' COMMENT '账户收入总计',
  PRIMARY KEY (id),
  UNIQUE KEY (name)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
INSERT INTO trade VALUES (1,'乔布斯','18012345678',0.00,0.00,0.00);
insert into trade value (2,'巴菲特','17812345678',234,123,999);
insert into trade value (3,'小李','15823458888',100000,100000,100000);

==================Python===================

使用Python脚本实现增删改查和事务处理,源码如下:

import pymysql.cursors
# 连接数据库
connect = pymysql.connect(
    host='localhost',
    port=3306,
    user='root',
    password='123456',
    db='小李',
    charset='utf8'
)
# 获取游标
cursor = connect.cursor()

# 插入数据
sql = "insert into trade (name ,account,saving) VALUES ('%s','%s',%.2f)"
data = ('周鸿祎', '13745675656', 55000)
cursor.execute(sql % data)   # 执行数据库的命令
connect.commit()  # 提交当前事务
print('成功插入', cursor.rowcount, '条数据')

# 修改数据
sql = "update trade set saving = %.2f where account = '%s'"
data = (3333, '13745672222')
cursor.execute(sql % data)   # 执行数据库的命令
connect.commit()  # 提交当前事务
print('成功修改', cursor.rowcount, '条数据')

# 查询数据
sql = "select name,saving from trade where account = '%s'"
data = ('15823458888',)
cursor.execute(sql % data)
for row in cursor.fetchall():   # 使用循环,用游标的方法获取结果集中的所有行
    print("Name:%s\tSaving:%.2f" % row)
connect.commit()
print('成功查询', cursor.rowcount, '条数据')

# 删除数据
sql = "delete from trade where account = '%s' limit %d"
data = ('13745672222', 1)
cursor.execute(sql % data)   # 执行数据库的命令
connect.commit()
print('成功删除', cursor.rowcount, '条数据')

# 事务处理
sql_1 = "update trade set saving = saving + 1000 where account = '17812345678'"
sql_2 = "update trade set expend = expend + 1000 where account = '17812345678'"
sql_3 = "update trade set income = income + 1000 where account = '17812345678'"

try:
    cursor.execute(sql_1)  # 储蓄增加1000
    cursor.execute(sql_2)  # 支出增加1000
    cursor.execute(sql_3)  # 收入增加1000
except Exception as e:
    connect.rollback()     # 事务回滚
    print('事务处理失败', e)
else:
    connect.commit()       # 事务提交
    print('事务提交', cursor.rowcount, '条数据')

# 关闭连接
cursor.close()
connect.close()

==================测试结果===================

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值