Python连接操作数据库(python连接数据库代码)
off999 2024-10-12 06:14 24 浏览 0 评论
mysql
python3中用pymysql操作mysql数据库
pip3 install PyMySQL
图片描述
图片描述
import pymysql
conn = pymysql.Connect(host='127.0.0.1',port=3306,user='root',passwd='zk1991zk',db='mytest',charset='utf8')
cursor = conn.cursor()
sql = "select * from user"
cursor.execute(sql)
rs = cursor.fetchall()
print('rs:', rs)
for each in rs:
print(each)
图片描述
更新数据库insert/update/delete
不同于select操作,这三个操作修改了数据库内容,所以需要commit(),否则数据库没有做相应的更改,但是也不会报错。
import pymysql
conn = pymysql.Connect(host='127.0.0.1', port=3306, user='root', passwd='zk1991zk',db="mytest")
conn.autocommit(False)
cursor = conn.cursor()
sqlInsert = "insert into user(id, name) value('6','Alex')"
sqlUpdate = "update user set name = 'Jason',email='sha5xiang@gmail.com' where id = '2'"
sqlDelete = "delete from user where id='6' "
try:
cursor.execute(sqlInsert)
print(cursor.rowcount)
cursor.execute(sqlUpdate)
print(cursor.rowcount)
cursor.execute(sqlDelete)
print(cursor.rowcount)
conn.commit()
except Exception as e:
print("Reason:", e)
conn.rollback()
cursor.close()
cursor.close()
图片描述
图片描述
图片描述
mysql-connector
安装:
pip install mysql-connector
1、作用
mysql 模块的再包装,并支持 with语法。
将使用简化抽象为:
- 连接数据库;
- 执行sql语句并获得返回结果;
- 关闭数据库(使用with的时候可以省略);
2、示例
示例1(with语法)
# 连接数据库
with MySQLTool(user=user, password=pw, database=database) as m2:
# 执行sql并获得返回结果
result2 = m2.run_sql([
['insert person(name, age) values ("李四", 20), ("王五", 30)'],
['select * from person']
])
# 打印结果
print(result2)
示例2(普通语法)
m = MySQLTool()
# 查看mysql容器内 ip,参考这个链接:https://blog.csdn.net/CSDN_duomaomao/article/details/75638544
m.connect(user=user,
password=pw,
# host=ip,
database=database)
result = m.run_sql([
['insert person(name,age) values (%s, %s)', ['六六六', 666]],
['select * from person']
])
print(result)
m.close()
示例
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import sys
from mysql import connector
from ..printcolor_lingling import print_testresult
import time
_user = ''
_password = ''
_database = ''
_host = '127.0.0.1'
_port = 3306
_unix_socket = None
def errlog(msg):
with open('./log/mysql-err.log', 'a')as f:
f.write('%s||%s:%s\n' % (
time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()),
sys._getframe(1).f_code.co_name, # 执行errlog这个函数的函数名字,即上一级函数
msg
))
def sqllog(sql, args=[]):
with open('./log/mysql.log', 'a')as f:
f.write('%s||%s:%s\n' % (
time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()),
sys._getframe(1).f_code.co_name, # 执行errlog这个函数的函数名字,即上一级函数
sql % tuple(args)
))
class MySQLTool(object):
def __init__(self, **args):
self.c = None
self.cursor = None
# 参数不足2个则直接扔掉,因为至少需要 root 和 password
if not ('user' in args and 'password' in args):
pass
else:
# 超过3个,取传的参数的值
self.args = args
# 连接到数据库,参数要么传值,要么使用默认值
# 这里的默认值是从 mysql/connector/abstracts.py 复制来的
def connect(self,
user=_user,
password=_password,
database=_database,
host=_host,
port=_port,
unix_socket=_unix_socket):
self.c = connector.connect(user=user,
password=password,
database=database,
host=host,
port=port,
unix_socket=unix_socket)
self.cursor = self.c.cursor()
# with 的时候执行,返回值是 with...as e 中的e的值
def __enter__(self):
self.connect(**self.args)
return self
# with 内部代码块执行完毕后执行
def __exit__(self, exc_type, exc_value, traceback):
if exc_type:
print('Error')
else:
self.close()
# 执行 SQL 语句,并返回最后一次查询的查询结果
# 如果错误,返回False,其他时候返回结果
# 适用于select时使用。建议insert和update使用专有函数
def run_sql(self, sql_list):
error = False
try:
# 依次执行 sql 语句
for sql in sql_list:
print('sql: %s', sql)
if len(sql) == 1:
self.cursor.execute(sql[0])
sqllog(sql[0])
else:
self.cursor.execute(*sql)
sqllog(sql[0], sql[1])
# 这里如果报错,说明操作是比如 create table 之类的操作,返回 None
result = self.cursor.fetchall()
except BaseException as e:
print(e)
error = True
errlog(str(e))
finally:
# 如果错误,返回False,其他时候返回结果
if error:
return False
else:
return result
# 更新专用函数。
# 错误返回False,未更新(比如说不需要更新)返回0,成功更新返回更新的行数,例如影响了2行数据就是2
def update_row(self, sql, args):
error = False
change_rows = None
try:
self.cursor.execute(sql, args)
sqllog(sql, args)
# 判断一下影响了多少条数据,如果为0条,说明啥事都没干
change_rows = self.get_cu_rowcount()
except BaseException as e:
print(e)
error = True
errlog(str(e))
finally:
# 如果错误,返回False,其他时候返回结果
if error:
return False
else:
return change_rows
# 插入一行。
# 插入失败(报错或无法插入)返回False,插入成功返回插入行的id
def insert_row(self, sql, args):
error = False
try:
# 正常情况下,返回值为None
self.cursor.execute(sql, args)
sqllog(sql, args)
# 判断一下影响了多少条数据,如果为0条,说明啥事都没干
change_rows = self.get_cu_rowcount()
if change_rows == 0:
error = True
except BaseException as e:
error = True
msg = str(e)
errlog(msg)
finally:
if error:
return False
else:
return self.get_last_insert_id()
# 同时插入多行(也可以只插入一行)
# 如果插入错误/或未成功插入,会返回False
# 插入成功,则返回插入的条数
# 示例:m.insert_more_rows(
# 'insert person(name,age) values (%s, %s)',
# [('六六六', 666)]
# )
def insert_more_rows(self, sql, args):
error = False
change_rows = None
try:
# 正常情况下,返回值为None
self.cursor.executemany(sql, args)
sqllog(sql, args)
# 判断一下影响了多少条数据,如果为0条,说明啥事都没干
change_rows = self.get_cu_rowcount()
if change_rows == 0:
error = True
except BaseException as e:
error = True
msg = str(e)
errlog(msg)
finally:
if error:
return False
else:
return change_rows
# 返回 cursor
def get_cursor(self):
return self.cursor
# 当上一次操作是插入或更新时,获取插入/更新影响的行数。比如插入一条就是一行
# 如果是 -1,表示上一次操作不是插入
def get_cu_rowcount(self):
return self.cursor.rowcount
# 获取上一个插入行的id(需要要插入后执行才能正确返回id,否则返回None)
def get_last_insert_id(self):
return self.cursor.lastrowid
# 手动提交事务,部分场景下可能有用
def commit(self):
self.c.commit()
# 关闭连接
def close(self):
self.cursor.close()
self.c.commit()
self.c.close()
# 测试代码和示例代码
# 以下代码的执行前提是本机有一个 mysql 的容器,这个容器参照这个链接
# https://github.com/qq20004604/docker-learning/tree/master/docker-demo-02-MySQL
if __name__ == '__main__':
is_error = False
try:
# 测试数据
user = 'docker'
pw = '1654879wddgfg'
database = 'docker_test_database'
# ---- 测试代码2 ----
# 连接数据库
with MySQLTool(user=user, password=pw, database=database) as m2:
# 执行sql并获得返回结果
result2 = m2.run_sql([
['insert person(name, age) values ("李四", 20), ("王五", 30)'],
['select * from person']
])
# 打印结果
print(result2)
print("——————————————————————")
# ---- 测试代码1 ----
m = MySQLTool()
# 查看mysql容器内 ip,参考这个链接:https://blog.csdn.net/CSDN_duomaomao/article/details/75638544
m.connect(user=user,
password=pw,
# host=ip,
database=database)
result = m.insert_more_rows(
'insert person(name,age) values (%s, %s)',
[('六六六', 666)]
)
if result is False:
is_error = True
result2 = m.insert_row(
'insert person(name,age) values (%s, %s)',
('六六六', 666)
)
if result is False:
is_error = True
m.close()
except BaseException as e:
print(e)
is_error = True
print_testresult(not is_error, 'MySQLTool')
下一章我们讲 银行转账实例的实现
注意点
- NoneType' object has no attribute 'encoding' ,之前指明的charset必须是"UTF8",不是"utf-8"/"UTF-8"
- MySQL语句后面必须有';',否则不会报错,也难以发现
- 数据库insert/update/delete操作需要commit()
- 在构造命令的时候,注意用 " 包裹起来,因为SQL语句字符串需要 ' 包裹。所以," 比较简单的避免歧义。
参考
python3操作MySQL数据库Python3读取Excel数据存入MySQL
相关推荐
- 全网第一个讲清楚CPK如何计算的Step by stepExcel和Python同时实现
-
在网上搜索CPK的计算方法,几乎全是照搬教材的公式,在实际工作做作用不大,甚至误导人。比如这个又比如这个:CPK=min((X-LSL/3s),(USL-X/3s))还有这个,很规范的公式,也很清晰很...
- [R语言] R语言快速入门教程(r语言基础操作)
-
本文主要是为了从零开始学习和理解R语言,简要介绍了该语言的最重要部分,以快速入门。主要参考文章:R-TutorialR语言程序的编写需要安装R或RStudio,通常是在RStudio中键入代码。但是R...
- Python第123题:计算直角三角形底边斜边【PythonTip题库300题】
-
1、编程试题:编写一个程序,找出已知面积和高的直角三角形的另外两边(底边及斜边)。定义函数find_missing_sides(),有两个参数:area(面积)和height(高)。在函数内,计算另外...
- Tensor:Pytorch神经网络界的Numpy
-
TensorTensor,它可以是0维、一维以及多维的数组,你可以将它看作为神经网络界的Numpy,它与Numpy相似,二者可以共享内存,且之间的转换非常方便。但它们也不相同,最大的区别就是Numpy...
- python多进程编程(python多进程进程池)
-
forkwindows中是没有fork函数的,一开始直接在Windows中测试,直接报错importosimporttimeret=os.fork()ifret==0:...
- 原来Python的协程有2种实现方式(python协程模型)
-
什么是协程在Python中,协程(Coroutine)是一种轻量级的并发编程方式,可以通过协作式多任务来实现高效的并发执行。协程是一种特殊的生成器函数,通过使用yield关键字来挂起函数的执行...
- ob混淆加密解密,新版大众点评加密解密
-
1目标:新版大众点评接口参数_token加密解密数据获取:所有教育培训机构联系方式获取难点:objs混淆2打开大众点评网站,点击教育全部,打开页面,切换到mobile模式,才能找到接口。打开开发者工具...
- python并发编程-同步锁(python并发和并行)
-
需要注意的点:1.线程抢的是GIL锁,GIL锁相当于执行权限,拿到执行权限后才能拿到互斥锁Lock,其他线程也可以抢到GIL,但如果发现Lock仍然没有被释放则阻塞,即便是拿到执行权限GIL也要立刻...
- 10分钟学会Python基础知识(python基础讲解)
-
看完本文大概需要8分钟,看完后,仔细看下代码,认真回一下,函数基本知识就OK了。最好还是把代码敲一下。一、函数基础简单地说,一个函数就是一组Python语句的组合,它们可以在程序中运行一次或多次运行。...
- Python最常见的170道面试题全解析答案(二)
-
60.请写一个Python逻辑,计算一个文件中的大写字母数量答:withopen(‘A.txt’)asfs:count=0foriinfs.read():ifi.isupper...
- Python 如何通过 threading 模块实现多线程。
-
先熟悉下相关概念多线程是并发编程的一种方式,多线程在CPU密集型任务中无法充分利用多核性能,但在I/O操作(如文件读写、网络请求)等待期间,线程会释放GIL,此时其他线程可以运行。GIL是P...
- Python的设计模式单例模式(python 单例)
-
单例模式,简单的说就是确保只有一个实例,我们知道,通常情况下类其实可以有很多实例,我们这么来保证唯一呢,全局访问。如配置管理、数据库连接池、日志处理器等。classSingleton: ...
- 更安全的加密工具:bcrypt(bcrypt加密在线)
-
作为程序员在开发工作中经常会使用加密算法,比如,密码、敏感数据等。初学者经常使用md5等方式对数据进行加密,但是作为严谨开发的程序员,需要掌握一些相对安全的加密方式,今天给大家介绍下我我在工作中使用到...
- 一篇文章搞懂Python协程(python协程用法)
-
前引之前我们学习了线程、进程的概念,了解了在操作系统中进程是资源分配的最小单位,线程是CPU调度的最小单位。按道理来说我们已经算是把cpu的利用率提高很多了。但是我们知道无论是创建多进程还是创建多线...
- Python开发必会的5个线程安全技巧
-
点赞、收藏、加关注,下次找我不迷路一、啥是线程安全?假设你开了一家包子铺,店里有个公共的蒸笼,里面放着刚蒸好的包子。现在有三个顾客同时来拿包子,要是每个人都随便伸手去拿,会不会出现混乱?比如第一个顾...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python字典遍历 (54)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (60)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)