Python資料庫封裝實現程式碼示例解析
阿新 • • 發佈:2020-09-07
Django中(原生mysql封裝)
1.函式封裝
import pymysql # 查 所資料 def get_all(sql): conn = pymysql.connect(host="localhost",user="root",password="root",database="db6") cur = conn.cursor(cursor=pymysql.cursors.DictCursor) cur.execute(sql) res = cur.fetchall() cur.close() conn.close() return res # 查 一行資料 def get_one(sql,args): conn = pymysql.connect(host="localhost",database="db6") cur = conn.cursor(cursor=pymysql.cursors.DictCursor) cur.execute(sql,args) res = cur.fetchone() cur.close() conn.close() return res # 增 刪 改 都要提交 commit def get_mif(sql,args) conn.commit() cur.close() conn.close() # 增 刪 改 都要提交 commit # 新增並且帶返回值 def get_create(sql,args): conn = pymysql.connect(host="localhost",database="db6") cur = conn.cursor(cursor=pymysql.cursors.DictCursor) cur.execute(sql,args) conn.commit() cur.close() conn.close() return cur.lastrowid # python插入記錄後取得主鍵id的方法(cursor.lastrowid和conn.insert_id()) # 增 刪 改 都要提交 commit # 批量加入 以元祖的形式傳引數 就是新增幾次次提交一次 def mul_mode(sql,database="db6") cur = conn.cursor(cursor=pymysql.cursors.DictCursor) # self.cursor.executemany("insert into user (id,name) values (%s,%s)",[(1,"aaa"),(2,"bbb"),(3,"ccc")]) 傳參方式 cur.executemany(sql,args) conn.commit() cur.close() conn.close()
2.物件封裝
import pymysql # 注意 args 引數可以傳空值[] class Mysqls(object): def __init__(self): # 讀取配置檔案 self.connect() def connect(self): self.conn = pymysql.connect(host="localhost",database="db6") # 可以把主機連線等寫入配置檔案 等 self.cursor=self.conn.cursor(cursor=pymysql.cursors.DictCursor) # 獲取所以資料 def get_all(self,sql,args): self.cursor.execute(sql,args) res = self.cursor.fetchall() return res # 獲取一行資料 def get_one(self,args): self.cursor.execute(sql,args) res = self.cursor.fetchone() return res # 新增 就是新增一次提交多次 def get_mode (self,args) self.conn.commit() # 新增並且帶返回值 def get_create(self,args) self.conn.commit() return self.cursor.lastrowid # python插入記錄後取得主鍵id的方法(cursor.lastrowid和conn.insert_id()) # 批量加入 以元祖的形式傳引數 就是新增一次提交一次 def mul_mode(self,args): # self.cursor.executemany("insert into user (id,"ccc")]) 傳參方式 self.cursor.executemany(sql,args) self.conn.commit() def get_close(self): self.cursor.close() self.conn.close()
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。