色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

python數(shù)據(jù)庫批量插入數(shù)據(jù)的實(shí)現(xiàn)(executemany的使用)

瀏覽:3日期:2022-06-20 16:01:03

正常情況下往數(shù)據(jù)庫多張表中批量插入1000條數(shù)據(jù),若一條一條insert插入,則調(diào)用sql語句查詢插入需要執(zhí)行幾千次,花費(fèi)時(shí)間長(zhǎng)

現(xiàn)使用cursor.executemany(sql,args) ,可對(duì)數(shù)據(jù)進(jìn)行批量插入,其中args是一個(gè)包含多個(gè)元組的list列表,每個(gè)元組對(duì)應(yīng)mysql當(dāng)中的一條數(shù)據(jù)

以下是實(shí)例:往數(shù)據(jù)庫中的order表、order_detail表和pay表中插入1000條訂單數(shù)據(jù),訂單詳情數(shù)據(jù)以及支付數(shù)據(jù)1.pay表中的id字段是order表中的pay_id字段2.order表中的id字段是order_detail表中的order_id字段

1.初始化屬性(包括host、port、user、password和database)

def __init__(self):self.__db_host=XXXself.__db_port=XXXself.__db_user=XXXself.__db_password=XXXself.__db_database=XXX

2.連接數(shù)據(jù)庫

def isConnection(self):self.__db=pymysql.connect( host=self.__db_host, port=self.__db_port, user=self.__db_user, password=self.__db_password, database=self.__db_database, charset=’utf8’)

3.批量往pay表中插入1000條數(shù)據(jù)

# 插入數(shù)據(jù)進(jìn)pay表 def pay_insert(self,pay_value):try: # 連接數(shù)據(jù)庫 self.isConnection() # 創(chuàng)建游標(biāo) global cursor cursor=self.__db.cursor() # 執(zhí)行 cursor.executemany(’insert into `pay表`(type,pay_money,pay_time,pay_no,STATUS,create_by,create_time,update_by,update_time) value (%s,%s,%s,%s,%s,%s,%s,%s,%s)’,pay_value)except Exception as e: print efinally: cursor.close() self.__db.commit() self.__db.close() # 生成pay表所需字段,并調(diào)用sql def pay_data(self):pay_value=list()for i in range(1,1000): pay_value.append((0,8800,time.localtime(),str(random.randint(712300000000,712399999999)),3,49338,time.localtime(),49338,time.localtime()))now_time=time.localtime()self.pay_insert(pay_value)return now_time

4.pay表中生成的1000條數(shù)據(jù),依次取出id

# 獲取pay_id def get_pay_id(self,now_time):try: self.isConnection() global cursor cursor=self.__db.cursor() cursor.execute(’select id from `pay表` where create_time >= %s’,now_time) id_value=list() for i in range(1,1000):pay_id=cursor.fetchone()id_value.append(pay_id) return id_valueexcept Exception as e: print efinally: cursor.close() self.__db.commit() self.__db.close()

以下是完整代碼:

# #!/usr/bin/python# # -*- coding: UTF-8 -*-import pymysql # 先pip install pymysqlimport randomimport timeclass DatabaseAcess: # 初始化屬性(包括host、port、user、password和database) def __init__(self):self.__db_host=XXXself.__db_port=XXXself.__db_user=XXXself.__db_password=XXXself.__db_database=XXX # 連接數(shù)據(jù)庫 def isConnection(self):self.__db=pymysql.connect( host=self.__db_host, port=self.__db_port, user=self.__db_user, password=self.__db_password, database=self.__db_database, charset=’utf8’) # 插入數(shù)據(jù)進(jìn)pay表 def pay_insert(self,pay_value):try: # 連接數(shù)據(jù)庫 self.isConnection() # 創(chuàng)建游標(biāo) global cursor cursor=self.__db.cursor() # 執(zhí)行 cursor.executemany(’insert into `pay表`(type,pay_money,pay_time,pay_no,STATUS,create_by,create_time,update_by,update_time) value (%s,%s,%s,%s,%s,%s,%s,%s,%s)’,pay_value)except Exception as e: print efinally: cursor.close() self.__db.commit() self.__db.close() # 生成pay表所需字段,并調(diào)用sql def pay_data(self,data_number):pay_value=list()for i in range(1,data_number): pay_value.append((0,8800,time.localtime(),str(random.randint(712300000000,712399999999)),3,49338,time.localtime(),49338,time.localtime()))now_time=time.localtime()self.pay_insert(pay_value)return now_time # 獲取pay_id def get_pay_id(self,now_time,data_number):try: self.isConnection() global cursor cursor=self.__db.cursor() cursor.execute(’select id from `pay表` where create_time >= %s’,now_time) id_value=list() for i in range(1,data_number):pay_id=cursor.fetchone()id_value.append(pay_id) return id_valueexcept Exception as e: print efinally: cursor.close() self.__db.commit() self.__db.close() # 插入數(shù)據(jù)進(jìn)order表 def order_insert(self,order_value):try: self.isConnection() global cursor cursor=self.__db.cursor() cursor.executemany(’insert into `order表` (student_name,student_id,school_id,school_name,tel,height,sex,pay_id,order_no,status,original_price,payment_price,order_type,create_by,create_time,update_by,update_time,purchase_id,dept_id,sub_order_mid,class_name,shoe_size,student_no,weight) value (%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)’,order_value)except Exception as e: print efinally: cursor.close() self.__db.commit() self.__db.close() # 生成order表所需字段,并調(diào)用sql def order_data(self,id_value,data_number):order_value=list()for i in range(1,data_number): pay_id=str(id_value[i-1]).replace('L,)','').replace('(','') order_value.append(('周瑜',35999,346,'A城小學(xué)','13322222222',130,1,pay_id,str(random.randint(7100000000,7999999999)),2,8800,8800,1,49338,time.localtime(),49338,time.localtime(),405,121,564123698745632,'三年級(jí) 3班',30,30,30))sys_time=time.localtime()self.order_insert(order_value)return sys_time # 獲取order_id def get_order_id(self,sys_time,data_number):try: self.isConnection() global cursor cursor=self.__db.cursor() cursor.execute(’select id from `order表` where create_time >= %s’,sys_time) order_id_list=list() for i in range(1,data_number):order_id_list.append(cursor.fetchone()) return order_id_listexcept Exception as e: print efinally: cursor.close() self.__db.commit() self.__db.close() # 插入數(shù)據(jù)進(jìn)order_detail表 def order_detail_insert(self,detail_value):try: self.isConnection() global cursor cursor=self.__db.cursor() cursor.executemany(’insert into `order_details表` (order_id,commodity_name,commodity_id,original_price,payment_price,img,number,status,create_by,create_time,update_by,update_time) value (%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)’,detail_value)except Exception as e: print efinally: cursor.close() self.__db.commit() self.__db.close() # 生成order_detail表所需字段,并調(diào)用sql def order_detail_data(self,order_id_list,data_number):detail_value=list()for i in range(1,data_number): order_id=str(order_id_list[i-1]).replace('L,)','').replace('(','') detail_value.append((order_id,'A城小學(xué)春季校服','1382932636506902530',8800,8800,'https://ygxf-dev2.obs.cn-north-1.myhuaweicloud.com:443/image%2F1618551784845-589.jpg',1,2,49338,time.localtime(),49338,time.localtime()))self.order_detail_insert(detail_value)if __name__ == ’__main__’: db=DatabaseAcess() data_number=3 db.order_detail_data(order_id_list=db.get_order_id(sys_time=db.order_data(id_value=db.get_pay_id(now_time=db.pay_data(data_number=data_number),data_number=data_number),data_number=data_number),data_number=data_number),data_number=data_number) print ('{0}條數(shù)據(jù)插入完成'.format(data_number-1))

到此這篇關(guān)于python數(shù)據(jù)庫批量插入數(shù)據(jù)的實(shí)現(xiàn)(executemany的使用)的文章就介紹到這了,更多相關(guān)python數(shù)據(jù)庫批量插入 內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 欧美日韩精品一区二区三区高清视频 | 成人一级| 日b毛片 | 91久久国产口精品久久久久 | 久久亚洲成人 | 老湿菠萝蜜在线看 | 亚洲深夜福利视频 | 国产精选在线 | 毛片大全免费 | 久久精品国产精品亚洲艾 | 怡红院最新免费全部视频 | 午夜伊人 | 偷拍自拍第一页 | 亚洲欧美日本国产综合在线 | 日韩欧美一级 | 永久精品免费影院在线观看网站 | 亚洲超大尺度激情啪啪人体 | 亚洲美女综合 | 国产一区二区三区在线观看精品 | 国产美女视频黄a视频全免费网站 | 午夜限制r级噜噜片一区二区 | 亚洲欧美久久精品一区 | 日韩欧美一区二区不卡看片 | 欧美视频一区二区三区精品 | 欧美aaa视频 | 成人久久 | 在线亚洲v日韩v | 在线播放日韩 | 国产日本韩国 | 亚洲成a人片在线看 | 一区二区三区四区在线免费观看 | 成 人免费va视频 | 免费看欧美一级片 | 国产愉拍精品手机 | 欧美人交性视频在线香蕉 | 日韩 综合 | 日韩一区二区三区在线 | 成人欧美视频在线观看 | 九九九在线视频 | 国内精品久久久久久影院老狼 | 国产99久久精品 |