Flask学习(七):pymysql链接数据库

1、pymysql链接数据库相关参数: conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', password='root', db='smbms')

def __init__(self,*,user=None, password="", host=None, database=None, unix_socket=None,port=0,charset="",collation=None,sql_mode=None,read_default_file=None,conv=None,use_unicode=True,client_flag=0,cursorclass=Cursor,init_command=None,connect_timeout=10,read_default_group=None,autocommit=False,local_infile=False,max_allowed_packet=16 * 1024 * 1024,defer_connect=False,auth_plugin_map=None,read_timeout=None,write_timeout=None,bind_address=None,binary_prefix=False,program_name=None,server_public_key=None,ssl=None,ssl_ca=None,ssl_cert=None,ssl_disabled=None,ssl_key=None,ssl_verify_cert=None,ssl_verify_identity=None,compress=None,  # not supportednamed_pipe=None,  # not supportedpasswd=None,  # deprecateddb=None,  # deprecated
):

参数说明:

  • host- 数据库服务器所在的主机

  • user- 登录的用户名

  • password- 要使用的密码。

  • database - 要使用的数据库,None不使用特定的数据库。

  • port - 要使用的MySQL端口,默认通常都可以。(默认值:3306

  • bind_address- 当客户端具有多个网络接口时,请指定从中连接到主机的接口。参数可以是主机名或IP地址。

  • unix_socket- 您可以选择使用unix套接字而不是TCP / IP。

  • read_timeout- 以秒为单位读取连接的超时(默认值:无 - 无超时)

  • write_timeout - 以秒为单位写入连接的超时(默认值:无 - 无超时)

  • charset- 你要使用的Charset。

  • sql_mode- 要使用的默认SQL_MODE

  • read_default_file- 指定my.cnf文件以从[client]部分下读取这些参数。

  • conv - 使用转换字典而不是默认字典。这用于提供类型的自定义编组和解组。见转换器。

  • use_unicode- 是否默认为unicode字符串。对于Py3k,此选项默认为true

  • client_flag- 要发送给MySQL的自定义标志。在constants.CLIENT中查找潜在值。

  • cursorclass- 要使用的自定义游标类。

  • init_command- 建立连接时要运行的初始SQL语句。

  • connect_timeout- 连接时抛出异常之前的超时。(默认值:10,最小值:1,最大值:31536000)

  • ssl- 类似于mysql_ssl_set()参数的参数的dict

  • read_default_group- 要在配置文件中读取的组。

  • named_pipe- 不支持

  • autocommit- 自动提交模式。无表示使用服务器默认值。(默认值:False

  • local_infile - 允许使用LOAD DATA LOCAL命令的布尔值。(默认值:False

  • max_allowed_packet- 发送到服务器的最大数据包大小(以字节为单位)。(默认值:16MB)仅用于限制小于默认值(16KB)的LOAD LOCAL INFILE数据包的大小。

  • defer_connect- 不要在构造上显式连接 - 等待连接调用。(默认值:False

  • auth_plugin_map- 插件名称的一个字典,用于处理该插件的类。该类将Connection对象作为构造函数的参数。该类需要一个认证方法,将认证包作为参数。对于对话框插件,可以使用提示(echoprompt)方法(如果没有authenticate方法)从用户返回字符串。(实验)

  • server_public_key - SHA256身份验证插件公钥值。(默认:无)

  • db- 数据库的别名。(与MySQLdb兼容)

  • passwd- 密码的别名。(与MySQLdb兼容)

  • binary_prefix- 在字节和bytearray上添加_binary前缀。(默认值:False

2、相关方法:

  • begin()开始事物。

  • close()发送退出消息并关闭套接字。请参阅 规范中的Connection.close()​

  • commit()​提交更改为稳定存储。请参阅 规范中的Connection.commit()​

  • cursor(cursor = None)创建一个新游标以执行查询。常用的游标类型如下:

    • Cursor:使用此游标类,返回结果为元组类型。

    • DictCursor:使用此游标类,返回结果为字典类型。

    • SSCursor:使用此游标类,返回结果为元组类型。不缓存结果,适合处理大量数据,但对于内存敏感的应用,对性能的影响较大。

    • SSDictCursor:使用此游标类,返回结果为字典类型。不缓存结果,适合处理大量数据,但对于内存敏感的应用,对性能的影响较大。

    • 其中, CursorDictCursor 是最常用的两种游标类。

    • 使用 Cursor 游标类,返回的结果为元组类型,每个元组表示一行数据;

    • 使用 DictCursor 游标类,返回结果为字典类型,以字典的形式表示每行数据,字典的键是列名,值是对应的值。

    • SSCursorSSDictCursor 则是无缓存的游标类,适合处理大量数据,但对内存敏感的应用不友好,也不支持fetchmany()scroll() 方法。

  • open如果连接打开,则返回​True

  • ping(reconnect = True)​检查服务器是否处于活动状态。参数:重新连接 - 如果连接已关闭,请重新连接。rollback() ​回滚当前事务。请参阅 规范中的Connection.rollback()。

  • select_db(db )​设置当前数据库。参数:db - 数据库的名称。

  • show_warnings()​发送SHOW WARNINGS​SQL命令。

3、代码如下所示:

import pymysql
​
def getInfo():# 创建sql链接conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', password='root', db='smbms')# 创建游标 返回数据为元组形式cursor = conn.cursor(pymysql.cursors.DictCursor)# 执行sql语句cursor.execute('select * from smbms_user')# 返回所有数据rows = cursor.fetchall()# 返回一行数据row = cursor.fetchone()# 提交事务conn.commit()# 关闭资源cursor.close()conn.close()print(rows)print(row)
​
if __name__ == "__main__":getInfo()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/788357.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

分布式锁的几种实现方式

详解 Redis 分布式锁的 5 种方案-腾讯云开发者社区-腾讯云 面试官:了解分布式锁?说说ZooKeeper分布式锁的实现原理_为什么说zookeepr是天然的分布式锁-CSDN博客面试官:了解分布式锁?说说ZooKeeper分布式锁的实现原理_为什么说zoo…

OpenCV项目实战-深度学习去阴影-图像去阴影

往期热门博客项目回顾: 计算机视觉项目大集合 改进的yolo目标检测-测距测速 路径规划算法 图像去雨去雾目标检测测距项目 交通标志识别项目 yolo系列-重磅yolov9界面-最新的yolo 姿态识别-3d姿态识别 深度学习小白学习路线 //正文开始! 图…

不可变集合、Stream流、方法引用

一、不可变集合 是一个长度不可变,内容也无法修改的集合 定义完成后不可以修改,或者添加、删除 不可变集合分类 不可变的list集合 不可变的set集合 不可变的map集合 如何创建不可变集合? List、Set、Map接口中,都存在of方法可…

k8s的ClusterIP和NodePort类型有何不同

Kubernetes(K8s)是一个开源的容器编排平台,用于自动部署、扩展和管理容器化应用程序。在Kubernetes中,服务(Service)是一个抽象层,它定义了一种访问Pods(运行中的容器)的…

备战蓝桥杯---贪心刷题1

话不多说&#xff0c;直接看题&#xff1a; 本质是一个数学题&#xff1a; 我们令xi<0表示反方向传递&#xff0c;易得我们就是求每一个xi的绝对值之和min,我们令平均值为a爸。 易得约束条件&#xff1a; x1-x2a1-a,x2-x3a2-a..... 解得x1x1-0,x2x1-((n-1)*a-a2-...an)。…

LLM - 大语言模型 基于人类反馈的强化学习(RLHF)

欢迎关注我的CSDN:https://spike.blog.csdn.net/ 本文地址:https://blog.csdn.net/caroline_wendy/article/details/137269049 基于人类反馈的强化学习(RLHF,Reinforcement Learning from Human Feedback),结合 强化学习(RL) 和 人类反馈 来优化模型的性能。这种方法主要包…

pair作为unordered_map的key报错

问题 pair作为unordered_map的key报错&#xff0c;编译时会报错 原因 因为pair没有哈希函数 解决方法 定义哈希函数 template <typename T> inline void hash_combine(std::size_t &seed, const T &val) {seed ^ std::hash<T>()(val) 0x9e3779b9 (…

Jamba: A Hybrid Transformer-Mamba Language Model

Jamba: A Hybrid Transformer-Mamba Language Model 相关链接&#xff1a;arXiv 关键字&#xff1a;hybrid architecture、Transformer、Mamba、mixture-of-experts (MoE)、language model 摘要 我们介绍了Jamba&#xff0c;一种新的基于新颖混合Transformer-Mamba混合专家&am…

xilinx fpga程序固化

一、前言 xilinx 旗下的产品主要有包含有处理器的SOC系列&#xff0c;也有只有纯逻辑的fpga&#xff0c;两者的程序固化的方法并不相同&#xff0c;本文介绍只包含纯逻辑而不涉及处理器的fpga的代码固化。 二、固化流程 将工程综合&#xff0c;实现&#xff0c;并得到比特流…

MYSQL-7.内存

内存 Mysql的内存结构 大体可分为四个板块&#xff1a;mysql工作组件、线程本地内存、mysql共享内存、存储引擎缓冲区&#xff1b; Mysql server工作组件 对应着mysql架构图中的组件层&#xff1a; Mysql在启动时&#xff0c;会将这些工作组件初始化到内存中&#xff1b; …

MSSQL有关数据库、表的循环操作可使用的存储过程 sp_MSforeachdb 及 sp_MSforeachtable

MSSQL有关数据库、表的循环操作可使用的存储过程: 1. sp_MSforeachdb command1print ?, command2DBCC CHECKDB(?) --检查所有的数据库 2. sp_MSforeachtable command1print ?, command2sp_spaceused ? --统计各个表的空间使用情况 ​ 【说明】sys.​sp_MSforeachdb 和 …

【LAMMPS学习】七、加速性能(2)性能测试

7. 加速性能 7.1.基准测试 7.2.性能测试 在尝试让模拟运行得更快之前&#xff0c;您应该了解它当前的执行情况以及瓶颈所在。 做到这一点的最佳方法是在几个不同的处理器计数&#xff08;如果可能的话&#xff0c;包括单个处理器&#xff09;上运行您的系统&#xff08;实际…

【Vscode】无法将“python,pip,node,npm等”识别为cmdlet...问题

问题出现场景 新换个电脑&#xff0c;然后重新安装了软件&#xff0c;又复现一次又一次“老生常谈”的问题。 解决方法 网络答案吧五花八门&#xff0c;我采取一个我的场景解决可行的方案&#xff0c; 首先我的场景是&#xff0c;环境变量&#xff0c;配置路径都是没有问题…

抖音视频关键词批量下载工具|视频爬虫采集软件

抖音视频批量提取工具&#xff0c;搜索即下载&#xff0c;轻松获取所需视频&#xff01; 正文&#xff1a; 想要轻松获取抖音上的精彩视频吗&#xff1f;现在&#xff0c;有了我们的抖音视频批量提取工具&#xff0c;一切变得简单易行&#xff01;Q:290615413无论是针对特定关…

Nginx中间件服务:负载均衡(调度算法)

文章目录 引言I 原理1.1 后端服务器在负载均衡调度中的状态1.2 调度算法II upstreamd的应用2.1 加权负载均衡的服务器列表2.2 AB测试中使用upstream切分流量2.3 基于URL的HASH2.4 IP_HASHsee also引言 作用 转发功能:按照一定的调度算法(轮询、权重)将客户端发来的请求转发…

策略模式

定义&#xff1a; 策略模式定义了一系列算法&#xff0c;并将每个算法封装起来&#xff0c;使他们可以相互替换&#xff0c;且算法的变化不会影响到使用算法的客户。 优点&#xff1a; 1、算法可以自由切换。 2、避免使用多重条件判断。 3、扩展性良好。 缺点&#xff1a; 1、策…

基于Pytorch+昇腾NPU部署baichuan2-7B大模型

一、模型介绍 Baichuan 2 是百川智能推出的新一代开源大语言模型&#xff0c;采用 2.6 万亿 Tokens 的高质量语料训练。Baichuan 2 在多个权威的中文、英文和多语言的通用、领域 benchmark 上取得同尺寸最佳的效果。 它基于 Transformer 结构&#xff0c;在大约1.2万亿 tokens…

c++20协程详解(一)

前言 本文是c协程第一篇&#xff0c;主要是让大家对协程的定义&#xff0c;以及协程的执行流有一个初步的认识&#xff0c;后面还会出两篇对协程的高阶封装。 在开始正式开始协程之前&#xff0c;请务必记住&#xff0c;c协程 不是挂起当前协程&#xff0c;转而执行其他协程&a…

el-table\vxe-table深色背景Css样式

一、el-table 1、HTML <div class"table"><el-table:data"tableData":cell-class-name"tabCellClassName":row-class-name"tabRowClassName"border><!-- 序号 --><el-table-column type"index" labe…

pygame--坦克大战(二)

加载敌方坦克 敌方坦克的方向是随机的&#xff0c;使用随机数生成。 初始化敌方坦克。 class EnemyTank(Tank):def __init__(self,left,top,speed):self.images {U: pygame.image.load(img/enemy1U.gif),D: pygame.image.load(img/enemy1D.gif),L: pygame.image.load(img/e…