问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

python 操作数据库有必要单例吗

发布网友 发布时间:2022-05-02 11:36

我来回答

2个回答

懂视网 时间:2022-05-02 15:57

coding:utf-8 import threading import pymysql from DBUtils.PooledDB import PooledDB from app.common.file_config import get_config class DbPool(object): _instance_lock = threading.Lock() def __init__(self): if not hasattr(DbPool, "pool"): DbPool.mysql_pool() else: pass def __new__(cls, *args, **kwargs): if not hasattr(DbPool, "_instance"): with DbPool._instance_lock: if not hasattr(DbPool, "_instance"): DbPool._instance = object.__new__(cls, *args, **kwargs) return DbPool._instance @staticmethod def mysql_pool(): host = get_config(‘database‘, ‘MYSQL_HOST‘) port = int(get_config(‘database‘, ‘MYSQL_PORT‘)) user = get_config(‘database‘, ‘MYSQL_USERNAME‘) passwd = get_config(‘database‘, ‘MYSQL_PASSWORD‘) db = get_config(‘database‘, ‘MYSQL_DB‘) DbPool.pool = PooledDB( creator=pymysql, # 使用链接数据库的模块 mincached=2, # 初始化时,链接池中至少创建的空闲的链接,0表示不创建 maxcached=6, # 链接池中最多闲置的链接,0和None不限制 maxshared=3, # 链接池中最多共享的链接数量,0和None表示全部共享。PS: 无用,因为pymysql和MySQLdb等模块的 threadsafety都为1,所有值无论设置为多少,_maxcached永远为0,所以永远是所有链接都共享。 maxconnections=8, # 连接池允许的最大连接数,0和None表示不限制连接数 blocking=True, # 连接池中如果没有可用连接后,是否阻塞等待。True,等待;False,不等待然后报错 maxusage=None, # 一个链接最多被重复使用的次数,None表示无限制 setsession=None, # 开始会话前执行的命令列表。如:["set datestyle to ...", "set time zone ..."] # ping MySQL服务端,检查是否服务可用。# 如:0 = None = never, 1 = default = whenever it is requested, 2 = when a cursor is created, 4 = when a query is executed, 7 = always host=host, port=port, user=user, passwd=passwd, db=db, use_unicode=False, charset=‘utf8‘ )

 

Python下Mysql数据连接池——单例

标签:tab   ati   一个   nec   sel   har   sha   ldb   unicode   

热心网友 时间:2022-05-02 13:05

你可以访问Python数据库接口及API查看详细的支持数据库列表。不同的数据库你需要下载不同的DB API模块,例如你需要访问Oracle数据库和Mysql数据,你需要下载Oracle和MySQL数据库模块。
DB-API 是一个规范. 它定义了一系列必须的对象和数据库存取方式, 以便为各种各样的底层数据库系统和多种多样的数据库接口程序提供一致的访问接口 。
Python的DB-API,为大多数的数据库实现了接口,使用它连接各数据库后,就可以用相同的方式操作各数据库。
Python DB-API使用流程:

引入 API 模块。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
如何分别真金和仿金首饰 怎样区分真金和仿金首饰呢 小学生新年晚会主持人的串词!!(不要太多)急 大大后天就需要了!!!_百度... 周年晚会策划公司 奥格瑞玛传送门大厅在哪 奥格瑞玛传送门大厅怎么走 锻炼颈椎的几个动作 水多久能结冰 冰能在多长时间内形成 请问水低于0度会结冰吗? 如何防止脱发严重 嘴唇上有黑印用蜜蜡和棉线去除了胡须 求粤语翻译!好多字不知道怎么表达!求给力! 突然的自我 歌词 翻译成粤语 怎么读? 大鱼海棠尿不湿怎么样? 妈之爱纸尿裤怎么样 突然的自我 那个粤语高手翻译一下发音 beaba怎样煮面条 蹦、蹿、跳,粤语怎样讲 齐齐哈尔人民银行征信中心在哪坐多少路公交车? 广东话里“忽然很怀念” 怎么说 beaba尿不湿怎样 突然想找个人结婚粤语翻译 BEABA 尿不湿怎么样,好不好 BEABA的冲奶器怎么样?看到爸爸去哪里吴尊用的就是这个 用粤语 突然想起你 怎么说? 问几句广东话 天猫的BEABA怎么样,BEABA的纸尿裤与拉拉裤哪个好? “猝”字广州话怎么读? beaba纸尿裤怎么样 普鲁申科为什么让莎莎练肌肉 广东话 偶尔 怎么说?我听好像 够唔够?? 发生山火以后要向哪里方向跑? 刚果金尼拉贡戈火山喷发引热议,它的威力可不能小视,遇此该如何自救逃生... 在火山爆发的时候怎样才能安全避难? 火山喷发如何自救? ...为当地带来哪些影响?火山喷发时如何自救逃生? 火山爆发要怎么样避免? 遇到火山喷发,你真的能逃离火山吗 怎样防御火山爆发? 如何知道所用的wifi密码 医药行业的4+7是是什么 百词斩到底怎么切换计划!!! 4十7=8+()怎么填空 用凑十法算出4+7=() 4+7分解加法 四与七相加的和是多少? 4加7等于 贵阳是4十7城市吗? 男人四十七有更年期吗 为什么百词斩补卡日历上传错误? 负4十7等于多少?