阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Python连接数据库的两种方式

358次阅读
没有评论

共计 2370 个字符,预计需要花费 6 分钟才能阅读完成。

使用 Python 来操作数据库,第一时间都会想到 MySQLdb 这个库,但是个人感觉还是 peewee 库比较好用,写出来的代码更加规范、更加优美。这里其他功能就不多讲了,这次以 truncate table 为例子对比下两个库的差异!

使用 MySQLdb 库来连接的例子

#!/usr/bin/python
#-*- coding:utf-8 -*-
#__author__ == ‘chenmingle’

import MySQLdb

mysql_db = {
    “name”: “test_db”,
    “host”: “127.0.0.1”,
    “port”: 3306,
    “user”: “root”,
    “pswd”: “Password”,
    “charset”: ‘utf8’
}

mydb = MySQLdb.connect(host=mysql_db[‘host’],
    user=mysql_db[‘user’],
    passwd=mysql_db[‘pswd’],
    db=mysql_db[‘name’])
cursor = mydb.cursor()

tables = [‘domains_Conf’,’dnspod_Conf’,’jz_domains_Conf’]

## create truncate query
for tab in tables:
    sql = ‘truncate table %s’ %(tab)
    cursor.execute(sql)

mydb.commit() # execute truncate query
cursor.close()
mydb.close()
print “Table truncated success!”

使用 peewee 库来连接 mysql 例子

#!/usr/bin/env python
# -*- coding: utf-8 -*-
__author__ = ‘chenmingle’

from peewee import *

mysql_db = {
    “name”: “test_db”,
    “host”: “127.0.0.1”,
    “port”: 3306,
    “user”: “root”,
    “pswd”: “Password”,
    “charset”: ‘utf8’
}

db = MySQLDatabase(mysql_db[‘name’], host=mysql_db[‘host’], user=mysql_db[‘user’], passwd=mysql_db[‘pswd’],
                  port=mysql_db[‘port’], charset=mysql_db[‘charset’])

class BaseModel(Model):
    class Meta:
        database = db
        database.get_conn().ping(True)

class DomainsConf(BaseModel):
    class Meta:
            db_table = “domains_Conf”

    dns_id = PrimaryKeyField()
    domain_id = IntegerField(index=True)
    types = CharField(max_length=64, default=’A’)
    hostname = CharField(max_length=64)
    line = CharField(max_length=64, default=’default’)
    ttl = CharField(max_length=64, default=’600′)
    value = TextField()
    status = CharField(max_length=32, default=’ENABLE’)

class DNSPODConf(BaseModel):
    class Meta:
        db_table = “dnspod_Conf”

    dns_id = PrimaryKeyField()
    type = CharField(max_length=64, default=’A’)
    name = CharField(max_length=64)
    line = CharField(max_length=64, default=’ 默认 ’)
    line_id = CharField(max_length=64, default=’0′)
    ttl = CharField(max_length=64, default=’60’)
    value = TextField()
    status = CharField(max_length=32, default=’1′)

class JZDomainsConf(BaseModel):
    class Meta:
        db_table = “jz_domains_Conf”

    dns_id = PrimaryKeyField()
    domain_id = IntegerField(index=True)
    types = CharField(max_length=64, default=’A’)
    hostname = CharField(max_length=64)
    line = CharField(max_length=64, default=’default’)
    ttl = CharField(max_length=64, default=’600′)
    value = TextField()
    status = CharField(max_length=32, default=’ENABLE’)

if __name__ == ‘__main__’:
    DomainsConf.truncate_table()
    DNSPODConf.truncate_table()
    JZDomainsConf.truncate_table()

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计2370字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7800563
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
优雅、强大、轻量开源的多服务器监控神器

优雅、强大、轻量开源的多服务器监控神器

优雅、强大、轻量开源的多服务器监控神器 在多台服务器同时运行的环境中,性能监控、状态告警、资源可视化 是运维人...
Prometheus:监控系统的部署与指标收集

Prometheus:监控系统的部署与指标收集

Prometheus:监控系统的部署与指标收集 在云原生体系中,Prometheus 已成为最主流的监控与报警...
免费领取huggingface的2核16G云服务器,超简单教程

免费领取huggingface的2核16G云服务器,超简单教程

免费领取 huggingface 的 2 核 16G 云服务器,超简单教程 前言 HuggingFace.co...
仅2MB大小!开源硬件监控工具:Win11 无缝适配,CPU、GPU、网速全维度掌控

仅2MB大小!开源硬件监控工具:Win11 无缝适配,CPU、GPU、网速全维度掌控

还在忍受动辄数百兆的“全家桶”监控软件?后台偷占资源、界面杂乱冗余,想查个 CPU 温度都要层层点选? 今天给...
星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛 NAS 硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话? 前言 在选择 NAS 用预...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
每天一个好玩的网站-手机博物馆-CHAZ 3D Experience

每天一个好玩的网站-手机博物馆-CHAZ 3D Experience

每天一个好玩的网站 - 手机博物馆 -CHAZ 3D Experience 一句话介绍:一个用 3D 方式重温...
4盘位、4K输出、J3455、遥控,NAS硬件入门性价比之王

4盘位、4K输出、J3455、遥控,NAS硬件入门性价比之王

  4 盘位、4K 输出、J3455、遥控,NAS 硬件入门性价比之王 开篇 在 NAS 市场中,威...
星哥带你玩飞牛 NAS-10:备份微信聊天记录、数据到你的NAS中!

星哥带你玩飞牛 NAS-10:备份微信聊天记录、数据到你的NAS中!

星哥带你玩飞牛 NAS-10:备份微信聊天记录、数据到你的 NAS 中! 大家对「数据安全感」的需求越来越高 ...
星哥带你玩飞牛NAS-14:解锁公网自由!Lucky功能工具安装使用保姆级教程

星哥带你玩飞牛NAS-14:解锁公网自由!Lucky功能工具安装使用保姆级教程

星哥带你玩飞牛 NAS-14:解锁公网自由!Lucky 功能工具安装使用保姆级教程 作为 NAS 玩家,咱们最...
星哥带你玩飞牛NAS硬件02:某鱼6张左右就可拿下5盘位的飞牛圣体NAS

星哥带你玩飞牛NAS硬件02:某鱼6张左右就可拿下5盘位的飞牛圣体NAS

星哥带你玩飞牛 NAS 硬件 02:某鱼 6 张左右就可拿下 5 盘位的飞牛圣体 NAS 前言 大家好,我是星...