Python 数据库封装

————哈喽,大倩倩又来啦 🙇‍♀️🙇‍♀️🙇‍♀️

鉴于各位小伙伴的代码能力参差不齐,而且实际项目中用到的程度也不一样,大概整理了几种封装的方法。算是从简单到难吧,看各位的实际需要自行选择自己能掌握的就 OK 拉~~🤞🤞🤞

1.封装 01

import pymysql
# 打开数据库连接
def query_db(sql):
  db = pysql.connct(
        "host" = "localhost",
        "port" = 3306,
        "user" = "test",
        "password" = "123456"
        )
  # 建立游标
  cursor = db.cursor()
  cursor.excute(sql)
  data=cursor.fetchall()
#读取数据
  print(data)
# 关闭数据库
  db.close()
if __name__=="__main__":
    query_db("select * from user where name='张三'")

这个方式的封装就比较简单,就是写了一个简单的函数,查询语句作为一个参数传入。

下面讲讲稍微高级点的封装~~~Go

2.封装 02

import pymysql
def get_conn():
  db = pysql.connct(
      "host" = "localhost",
       "port" = 3306,
       "user" = "test",
       "password" = "123456"
  )
  return db
def query_db(sql):
  db=get_conn()
  cursor=db.cursor()
  cursor.excute(sql)
  data = cursor.fetchall()
  # 读取数据
  print(data)
  # 关闭数据库
  db.close()
if __name__=="__main__":
  query_db("select * from user where name='张三'")

这种方法是把数据库的连接配置单独写成一个函数,这样每次在想要用到数据库的时候直接调用这个方法就好~~这个是不是比上面的写法更加高级一点点呢 😄 😄 😄 😄

3.封装 03

  1. 新建一个 config.py 的文件,写上数据库的配置;
# 数据配置
DB_API_TEST = {
    "host": "localhost",
    "port": 3306,
    "user": "test",
    "password": "123456",
    "db": "test_Hu"
}
DB_API_TEST2={略}

注:这里可以写很多个数据库的配置奥~~

  1. 新建新的 PY 文件来进行调用test.py
import pymysql
from config import DB_API_TEST
def get_conn():
    conn = pymysql.connect(**DB_API_TEST)
    return conn
# 查询
def query_db(conn,sql):
   conn = get_conn()
    # 2. 建立游标
    cur = conn.cursor()
    # 3. 执行sql
    cur.execute(sql)
    # 4. 获取数据
    result = cur.fetchall()
    return result
if __name__ == "__main__":
    print(query_db(conn, "select * from user"))
    conn.close()

4.封装 04

当有多个数据库的连接时,上诉的方法太繁琐了,每次都要写好多~~来来来,再给大家介绍一种再牛逼点的写法

import pymysql
from config import DB_API_TEST,DB_GAOZHONG_TEST  #导入2个数据库配置
def get_conn(db_confT):
    conn = pymysql.connect(**db_conf)
    return conn

def query_db(conn,sql):
    cur = conn.cursor()
    cur.execute(sql)
    return cur.fetchall()

if __name__ == "__main__":
    conn = get_conn(DB_API_TES)   #数据库配置信息作为参数
    sql_query = "select * from user;"
    query_db(conn, sql_query)
    conn.close()

数据库的配置当成一个参数传给函数,你想调用那个数据库,只要修改数据库配置以及查询语句就可以啦~~ 好啦,今天数据库的封装就给大家讲到这里啦,各位喜欢的话请多多关注和打赏奥,么么哒

下期:unittest模块讲解

赞我 🤞 赞我 🤞 赞我 🤞 赞我 🤞 赞我 🤞

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容

  • 他本是魏国皇太子,而她是他的妹妹,魏国的公主。 哪一年,敌国入侵。 “快从密道离开,母后为你们挡住敌军。” “开始...
    无觞先生阅读 540评论 0 0
  • MBA可以学到哪些知识? 一、工商管理相关的专业知识 MBA教育是一次非常全面和系统的工商管理学习。对于学习者来说...
    不爱喝绿茶阅读 100评论 0 0
  • 【书名】:《我的第一本思维导图入门书》 【作者】:胡雅茹 【篇目】:第一章—第二章(P1-P74) 001、思维导...
    大头的故事阅读 595评论 5 2
  • 父母在我眼中,一直是不胖不瘦、不高不矮的人。春节回老家,给父母亲买衣服,售货员问,老人腰围多大?不清楚。年龄多大...
    二呆猫阅读 603评论 0 1