日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

python db類用法說明

瀏覽:169日期:2022-07-18 13:44:20

我就廢話不多說了,大家還是直接看代碼吧~

import pymysql class DB: __host = ’localhost’ # 服務器地址 __username = ’root’ # 用戶名 __password = ’’ # 密碼 __database = ’test’ # 數據庫 __field = ’*’ # 查詢字段 __where = ’’ # 條件 __sql = False # 是否返回sql __join = ’’ # 聯表 __order = ’’ # 排序 __limit = ’’ # 數量 # 構造函數,在生成對象時調用 def __init__(self, table): try: # 打開數據庫連接 host, username, password, database self.db = pymysql.connect(self.__host, self.__username, self.__password, self.__database) except Exception as e: print(e) exit() # 使用 cursor() 方法創建一個游標對象 cursor self.cursor = self.db.cursor() self.table = table # 析構函數,釋放對象時使用 def __del__(self): try: # 關閉數據庫連接 self.db.close() except Exception as e: print(e) # 得到當前sql語句 def getSql(self): self.__sql = True return self # 字段 def field(self, str): self.__field = str return self # 聯表 def join(self, table, where): self.__join = ’ LEFT JOIN ’ + table + ’ ON ’ + where + ’ ’ return self # 條件 def where(self, param): self.__where = ’ WHERE ’ if isinstance(param, list): for i in param: if isinstance(i[2], list): tmp = ’(’ for j in i[2]: tmp += str(j) + ’,’ tmp += ’)’ self.__where += ’`’ + i[0] + ’` ’ + i[1] + ’ ’ + tmp + ’ AND ’ else: self.__where += ’`’ + i[0] + ’` ’ + i[1] + ’ ’ + str(i[2]) + ’ AND ’ else: self.__where = self.__where[0:-4] else: self.__where += param return self # 排序 def order(self, str): self.__order = ’ ORDER BY ’ + str return self # 數量 def limit(self, str): self.__limit = ’ LIMIT ’ + str return self # 增加 def insert(self, dict): key = value = ’’ for k, v in dict.items(): key += ’`’ + k + ’`,’ value += ’'’ + v + ’',’ key = key[0:-1] value = value[0:-1] sql = ’INSERT INTO ’ + self.table + ’ (’ + key + ’) VALUES (’ + value + ’)’ if self.__sql: return sql try: # 執行sql語句 ret = self.cursor.execute(sql) # 提交到數據庫執行 self.db.commit() return ret except Exception as e: # 如果發生錯誤則回滾 self.db.rollback() print(e) return 0 # 刪除 def delete(self): if self.__where: sql = 'DELETE FROM ' + self.table + self.__where if self.__sql: return sql try: # 執行sql語句 ret = self.cursor.execute(sql) # 提交到數據庫執行 self.db.commit() return ret except Exception as e: # 如果發生錯誤則回滾 self.db.rollback() print(e) return 0 else: raise BaseException(’沒有條件’) # 拋異常 # 修改 def update(self, dict): str = ’’ for k, v in dict.items(): str += ’`’ + k + ’`='’ + v + ’',’ str = str[0:-1] sql = ’UPDATE ’ + self.table + ’ SET ’ + str if self.__where: sql += self.__where if self.__sql: return sql try: # 執行sql語句 ret = self.cursor.execute(sql) # 提交到數據庫執行 self.db.commit() return ret except Exception as e: # 如果發生錯誤則回滾 self.db.rollback() print(e) return 0 # 查詢 def select(self): sql = 'SELECT ' + self.__field + ' FROM ' + self.table if self.__join: sql += self.__join if self.__where: sql += self.__where if self.__order: sql += self.__order if self.__limit: sql += self.__limit if self.__sql: return sql # 使用 execute() 方法執行 SQL 查詢 self.cursor.execute(sql) # 使用 fetchall() 方法獲取所有數據. data = self.cursor.fetchall() return data’’’DROP TABLE IF EXISTS `people`;CREATE TABLE `people` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL COMMENT ’名字’, `sex` varchar(7) DEFAULT ’’ COMMENT ’性別’, `job` varchar(6) DEFAULT ’’ COMMENT ’工作’, `age` varchar(6) DEFAULT ’’ COMMENT ’年齡’, `height` varchar(6) DEFAULT ’’ COMMENT ’身高’, `weight` varchar(6) DEFAULT ’’ COMMENT ’體重’, PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;INSERT INTO `people` VALUES (’1’, ’趙一’, ’男’, ’學生’, ’8’, ’120’, ’35’);INSERT INTO `people` VALUES (’2’, ’錢二’, ’女’, ’學生’, ’9’, ’111’, ’31’);INSERT INTO `people` VALUES (’3’, ’孫三’, ’男’, ’學生’, ’10’, ’123’, ’34’);INSERT INTO `people` VALUES (’4’, ’李四’, ’女’, ’學生’, ’11’, ’100’, ’30’);’’’db = DB(’people’) # 增加dict = {’name’: ’周五’, ’sex’: ’男’, ’job’: ’學生’, ’age’: ’8’, ’height’: ’121’, ’weight’: ’32’}data = db.insert(dict)print(data) # 刪除# data = db.where(’id=6’).delete()# print(data) # 修改# dict = {’age’: ’9’, ’height’: ’121’, ’weight’: ’31’}# data = db.where(’id=7’).update(dict)# print(data) # 查詢 優化where條件 ’id<11’# data = db.field(’id,name,age,job’).where([[’id’, ’>’, 1]]).order(’id desc’).limit(’3’).select()# print(data)

補充知識:python DB API cursor 常用接口

1. description

如果 cursor 執行了查詢的 sql 代碼。那么讀取 cursor.description 屬性的時候,將返回一個列表,這個列表中裝的是元組,元組中裝的分別

是 (name,type_code,display_size,internal_size,precision,scale,null_ok) ,其中 name 代表的是查找出來的數據的字段名稱,其他參數暫時用處不大。

2. rowcount

代表的是在執行了 sql 語句后受影響的行數。

3. close

關閉游標。關閉游標以后就再也不能使用了,否則會拋出異常。

4. execute(sql[,parameters])

執行某個 sql 語句。如果在執行 sql 語句的時候還需要傳遞參數,那么可以傳給 parameters 參數。示例代碼如下:

cursor.execute('select * from article where id=%s',(1,))

5. fetchone

在執行了查詢操作以后,獲取第一條數據。

6. fetchmany(size)

在執行查詢操作以后,獲取多條數據。具體是多少條要看傳的 size 參數。如果不傳 size 參數,那么默認是獲取第一條數據。

7. fetchall

獲取所有滿足 sql 語句的數據。

以上這篇python db類用法說明就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩精品高清不卡| 国产亚洲人成a在线v网站| 国产一区视频在线观看免费| 国产精品极品在线观看| 欧美日一区二区三区在线观看国产免 | 欧美特黄一级大片| 国产96在线亚洲| 高清在线一区| 性欧美videohd高精| 久久久久99| 亚洲特色特黄| 亚洲精品护士| 国产情侣一区| av免费不卡国产观看| 久久影视一区| 日韩精品免费一区二区夜夜嗨| 日韩精品一卡二卡三卡四卡无卡| 麻豆久久精品| 麻豆精品久久久| 日韩免费一区| 99国产精品99久久久久久粉嫩| 在线国产一区二区| 日韩高清二区| 日韩精品一区二区三区免费观影 | 国产精品qvod| 免费视频国产一区| 国产精品久久久久久模特 | 亚洲精品在线二区| 国产中文字幕一区二区三区| 日韩久久视频| 国产欧美大片| 久久人人88| 国产精品美女午夜爽爽| 日韩天堂在线| 国产欧美一区二区精品久久久 | 少妇精品在线| 亚洲成人不卡| 日韩视频1区| 日韩不卡视频在线观看| 视频一区中文字幕精品| 久久国产电影| 精品久久久久中文字幕小说| 蜜桃免费网站一区二区三区| 色一区二区三区四区| 欧美日韩xxxx| 一区二区精品| 国产视频一区三区| 国产aⅴ精品一区二区四区| 欧美一区精品| 日韩一区精品| 三级欧美韩日大片在线看| 国产精品国产三级国产在线观看| 91高清一区| 欧美国产91| 久久高清免费| 精品日韩毛片| 欧美午夜不卡影院在线观看完整版免费| 黄色精品视频| 在线人成日本视频| av免费不卡国产观看| а√天堂8资源中文在线| 国产精品久久久久久久久久10秀| 欧美激情亚洲| 国产一区二区三区四区二区| 精品国产网站| 欧美成a人免费观看久久| 久久久人人人| 久久蜜桃精品| 亚洲一卡久久| 日韩激情中文字幕| 国产日韩中文在线中文字幕| 国产精品一站二站| 久久精品国产成人一区二区三区| 国产一区福利| 欧美性感美女一区二区| 首页国产欧美日韩丝袜| 日韩精品导航| 日韩免费一区| 一区二区三区四区日韩| 国产精品久久久久久久久免费高清| 麻豆国产精品| 国产精品99一区二区| 亚洲欧美激情诱惑| 日韩欧美激情| 伊人久久国产| 男人操女人的视频在线观看欧美| 日本电影久久久| 高潮久久久久久久久久久久久久| 日本综合字幕| 色狠狠一区二区三区| 成人免费一区| 亚洲永久精品唐人导航网址| 国产精品网站在线看| 三上悠亚国产精品一区二区三区| 性色一区二区| 久久电影tv| 91精品国产自产观看在线| 国产 日韩 欧美 综合 一区| 首页国产欧美日韩丝袜| 日韩欧美精品一区| 日韩美女国产精品| 99久久婷婷| 国产精品三级| 亚洲精品动态| 波多野结衣一区| 国产精品福利在线观看播放| 日韩欧美另类中文字幕| 在线亚洲观看| 欧美中文字幕一区二区| 卡一卡二国产精品| 日韩福利视频导航| 亚洲精品三级| 亚洲国内欧美| 日韩在线欧美| 久久精品国产网站| 日本亚州欧洲精品不卡| 亚洲天堂久久| 日韩1区在线| 国产精东传媒成人av电影| 亚洲免费成人av在线| 亚洲综合丁香| 午夜欧美精品久久久久久久| 日韩久久精品网| 国产理论在线| 丝袜av一区| 国产高清一区二区| 九一精品国产| 91精品亚洲| 久久国产亚洲精品| 国产精品91一区二区三区| 蜜桃视频在线网站| 久久久久久免费视频| 欧美日韩亚洲在线观看| 欧美va天堂在线| 国产色综合网| 婷婷综合国产| 午夜在线视频一区二区区别 | 日韩精品一区二区三区中文 | 久久aⅴ国产紧身牛仔裤| 日韩和的一区二在线| 久久久精品五月天| 欧美女激情福利| 久久高清国产| 日韩一区免费| 精品91福利视频| 亚洲无线一线二线三线区别av| 亚洲中字黄色| 国产激情久久| 亚洲国产影院| 国产精品va| 欧美亚洲国产激情| 亚洲人成精品久久久| 欧美成人精品午夜一区二区| 欧美激情国产在线| 激情六月综合| 91免费精品国偷自产在线在线| 久久午夜影院| 久久成人精品| 夜鲁夜鲁夜鲁视频在线播放| 首页欧美精品中文字幕| 风间由美中文字幕在线看视频国产欧美| 婷婷成人在线| 九九99久久精品在免费线bt| 日韩电影在线视频| 国产亚洲电影| 国户精品久久久久久久久久久不卡| 亚洲毛片在线| 成人三级高清视频在线看| 蜜臀av在线播放一区二区三区| 天堂а√在线最新版中文在线| 水蜜桃久久夜色精品一区的特点| 国产日韩视频在线| 91精品观看| 久久中文在线| 青草久久视频| 亚洲一区免费| 群体交乱之放荡娇妻一区二区| 日韩不卡在线观看日韩不卡视频| 日韩伦理在线一区| 国产精品香蕉| 日本aⅴ亚洲精品中文乱码| 婷婷丁香综合| 99国产精品免费视频观看| 国产精品免费大片| 蜜桃av一区二区在线观看| 久久精品国产68国产精品亚洲| 美女高潮久久久| 国产精品午夜一区二区三区| 四虎精品一区二区免费| 尹人成人综合网| 精品中文一区| 激情久久久久久久| 欧美大黑bbbbbbbbb在线| 久久久久一区| 亚洲不卡系列| 激情欧美一区二区三区| 亚洲精品91| 亚洲一区二区三区高清不卡| 国产一区二区高清| 91精品一区国产高清在线gif|