python MySQLdb使用教程详解
作者:FishBear_move_on 时间:2024-01-28 06:29:51
本文主要内容python MySQLdb数据库批量插入insert,更新update的:
1.python MySQLdb的使用,写了一个基类让其他的sqldb继承这样比较方便,数据库的ip, port等信息使用json配置文件
2.常见的查找,批量插入更新
下面贴出基类代码:
# _*_ coding:utf-8 _*_
import MySQLdb
import json
import codecs
# 这个自己改一下啊
from utils.JsonUtil import get_json_from_file
def byteify(input):
"""
the string of json typed unicode to str in python
This function coming from stack overflow
:param input: {u'first_name': u'Guido', u'last_name': u'jack'}
:return: {'first_name': 'Guido', 'last_name': 'jack'}
"""
if isinstance(input, dict):
return {byteify(key): byteify(value)
for key, value in input.iteritems()}
elif isinstance(input, list):
return [byteify(element) for element in input]
elif isinstance(input, unicode):
return input.encode('utf-8')
else:
return input
def get_json_from_file(filename):
with open(filename) as jf:
jsondata = json.load(jf)
return byteify(jsondata)
class DbBase(object):
def __init__(self, **kwargs):
self.db_config_file = kwargs['db_config_file']
self.config_db(self.db_config_file)
def config_db(self, db_config_file):
data = get_json_from_file(db_config_file)
host = data['host']
user = data['user']
pwd = data['pwd']
db = data['db']
port = data['port']
self.tb_audit_mobile = data['tb_audit_mobile']
self.conn = MySQLdb.connect(host=host, port=port, user=user, passwd=pwd, db=db, charset="utf8", use_unicode=True)
self.cursor = self.conn.cursor()
子类的示例:
class DbAuditTestService(DbBase):
def __init__(self, **kwargs):
super(DbAuditTestService, self).__init__(**kwargs)
def getAdTestURl(self, beg, end):
sql = """select url, source from tb_name where create_date BETWEEN '%s' and '%s' """ % (beg, end)
self.cursor.execute(sql)
res = [row for row in self.cursor]
return res
def insert(self, lst_row):
"""batch insert, use ignore 避免索引唯一问题"""
try:
insert_sql = 'INSERT ignore INTO tb_ms_mobile_report_test (appid, source) VALUES (%s, %s)'
self.cursor.executemany(insert_sql, lst_row)
self.conn.commit()
except MySQLdb.OperationalError as e:
logger.info('%s' % e)
self.cursor.close()
self.conn.close()
self.config_db(self.db_config_file)
def update_ip_info(self, ip_info):
"""
batch update
[[voilate_right_rate, ip]]
:param ip_info:
:return:
"""
query = """
update tb_ms_audit_ip_info set
ip_right_rate=%s
where submit_ip=%s """
self.cursor.executemany(query, ip_info)
self.conn.commit()
def insert_all():
"""批量操作的示例"""
db_audit = DbAuditService(db_config_file='../config/mysql_police_audit.json')
size = db_audit.count()
db_audit_test = DbAuditTestService(db_config_file='../config/mysql_local_audit.json')
batch_size = 2000
for k in xrange(100000, size, batch_size):
logger.info('query limit %s ~ %s' % (k, batch_size))
lst_row = db_audit.query_limit(k, batch_size)
logger.info('convert_rows ')
lst_row = convert_rows(lst_row)
db_audit_test.insert(lst_row)
总结
以上所述是小编给大家介绍的python MySQLdb使用教程详解网站的支持!
来源:http://blog.csdn.net/haluoluo211/article/details/77721138
标签:python,mysqldb,使用
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
nodejs对项目下所有空文件夹创建gitkeep的方法
2024-05-08 09:37:40
python中类的属性和方法介绍
2023-10-22 05:14:47
python 将dicom图片转换成jpg图片的实例
2023-08-24 11:12:27
查看当前mysql使用频繁的sql语句(详解)
2024-01-18 19:58:47
gridview生成时如何去掉style属性中的border-collapse
2024-04-18 09:36:56
Django 批量插入数据的实现方法
2023-01-11 10:40:58
js和asp操作fso比较
2007-09-23 09:17:00
在Python中使用AOP实现Redis缓存示例
2021-09-12 11:18:45
另类读写:ACCESS中Field对象的标题属性
2008-11-28 16:47:00
学会sql数据库关系图(Petshop)
2024-01-28 18:43:23
![](https://img.aspxhome.com/file/2023/2/99942_0s.png)
如何列举Error的所有对象?
2010-01-12 20:01:00
PHP设计模式之观察者模式浅析
2023-05-27 12:20:11
Python使用贪婪算法解决问题
2022-04-13 10:23:14
python版学生管理系统
2023-07-27 07:21:46
![](https://img.aspxhome.com/file/2023/1/90451_0s.png)
用python 绘制茎叶图和复合饼图
2023-08-04 10:34:54
![](https://img.aspxhome.com/file/2023/7/61457_0s.png)
js 代码优化点滴记录
2024-05-28 15:41:47
CentOS 7.3上SQL Server vNext CTP 1.2安装教程
2024-01-27 06:01:48
![](https://img.aspxhome.com/file/2023/2/96172_0s.png)
九个Python列表生成式高频面试题汇总
2023-06-04 20:09:51
SQL触发器定义与使用
2024-01-28 09:21:27
Python遍历numpy数组的实例
2021-08-30 08:49:37