基于pymysql的MYSQL数据库操作

一、机制

pymysql库的操作有点类似os.system(),需要直接给出mysql语句,会返回影响行数、数据等信息。

二、安装库及创建数据库、表

PyMySQL-0.9.3 (至少安装这个版本以上,否则会在connect时报错)

 

为进行试验,绕开一些权限的问题,创建了新的数据库及表

create database test_databases;

create table newtable(key1 char(20) NOT NULL,key2  int(11) NOT NULL);

这里实验的表名为newtable,具体信息如下:

 

基于pymysql的MYSQL数据库操作_第1张图片

三、基本操作

注意对一行操作和对N行操作的不同。

注意游标的移动及类型。

import pymysql
# 创建连接
conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='3gynj20J', db='test_databases')
# # 创建游标,返回元祖型数据
# cursor = conn.cursor()
# 创建游标,返回字典型数据
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

#增1
effect_row = cursor.execute("insert into newtable values('a',1)")
print(effect_row)

#增N
effect_row = cursor.executemany("insert into newtable values(%s,%s)",[('b',2),('c',3)])
print(effect_row)

#改
effect_row = cursor.execute("update newtable set key1='A' where key2=1")
print(effect_row)

# 注意mysql的fetch*会使cursor查一条少一条,游标自动向后移动,row_1和row_N是不重复的
#查1
cursor.execute("select * from newtable")
row_1 = cursor.fetchone()
print(row_1)
#查N
row_N = cursor.fetchmany(2)
#查all
row_all = cursor.fetchall()
print(row_1,row_N,row_all)
# print(cursor)  # 是一个对象,不是list,
# for i in cursor:
#     print(i)
#查某个位置开始的几个
# cursor.scroll(1,mode='relative')  # 相对当前位置移动
cursor.scroll(2,mode='absolute') # 相对绝对位置移动
row_1 = cursor.fetchone()
print(row_1)

 

四、常见报错

1、KeyError: 255

安装更高版本的pymysql。pip install --upgrade PyMySQL

https://www.jianshu.com/p/f69e846558ab

2、pymysql.err.OperationalError: (1142, "UPDATE command denied to user 'root'@'localhost' for table 'status_by_user'")

对于mysql安装时自带的数据库及表,可以进行查询,但无法修改的问题,可以自己创建数据库及表。

 

 

 

 

 

https://www.cnblogs.com/aylin/p/5770888.html

你可能感兴趣的:(大数据)