python MySQLdb使用教程详解

作者:FishBear_move_on 时间:2024-01-28 06:29:51 

本文主要内容python MySQLdb数据库批量插入insert,更新update的:

1.python MySQLdb的使用,写了一个基类让其他的sqldb继承这样比较方便,数据库的ip, port等信息使用json配置文件

2.常见的查找,批量插入更新

python MySQLdb使用教程详解

下面贴出基类代码:


# _*_ 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,使用
0
投稿

猜你喜欢

  • 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
  • 如何列举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
  • 用python 绘制茎叶图和复合饼图

    2023-08-04 10:34:54
  • js 代码优化点滴记录

    2024-05-28 15:41:47
  • CentOS 7.3上SQL Server vNext CTP 1.2安装教程

    2024-01-27 06:01:48
  • 九个Python列表生成式高频面试题汇总

    2023-06-04 20:09:51
  • SQL触发器定义与使用

    2024-01-28 09:21:27
  • Python遍历numpy数组的实例

    2021-08-30 08:49:37
  • asp之家 网络编程 m.aspxhome.com