使用MySQL Connector/Python操作MySQLMariaDB数据库

 

by:授客 QQ1033553122

因目前MySQLdb并不支持python3.x,而MySQL官方已经提供了MySQL连接器,而且已经有支持Python3.x的版本,所以使用MySQL Connector/Python来操作数据库

 

测试环境:

win7 32位

JetBrains PyCharm 4.0.5

Python版本:Python 3.3.2

Windows (x86, 32-bit), MSI Installer Python 3.3

下载地址:http://dev.mysql.com/downloads/connector/python/

网盘下载地址:http://pan.baidu.com/s/1kTRqRht

 

 

dbconfig.conf配置:

[DATABASE]
host = 192.168.1.102
port = 3306
user =  testacc
passwd = test1234
db = 1dcq
charset = utf8

 

代码实践

#!/usr/bin/env python
# -*- coding:utf-8 -*-
 
__author__ = 'shouke'
 
import mysql.connector
from mysql.connector import  errorcode
import configparser
import sys
from datetime import date, datetime, timedelta
 
class GetDB:
    '''配置数据库IP,端口等信息,获取数据库连接'''
    def __init__(self, ini_file):
        config = configparser.ConfigParser()
 
        # 从配置文件中读取数据库服务器IP、域名,端口
        config.read(ini_file)
        self.host = config['DATABASE']['host']
        self.port = config['DATABASE']['port']
        self.user = config['DATABASE']['user']
        self.passwd = config['DATABASE']['passwd']
        self.db = config['DATABASE']['db']
        self.charset = config['DATABASE']['charset']
 
    def get_conn(self):
        try:
            conn = mysql.connector.connect(host=self.host, port=self.port, user=self.user, password=self.passwd, database=self.db, charset=self.charset)
            return conn
        except Exception as e:
            print('%s', e)
            sys.exit()
 
    # 创建数据库
    def create_database(self, cursor, db_name):
        try:
            cursor.execute("CREATE DATABASE IF NOT EXISTS {} DEFAULT CHARSET 'utf8'".format(db_name))
        except mysql.connector.Error as err:
            print('Failed creating database: {}'.format(err))
            exit(1)
 
    # 切换数据库
    def use_database(self, cursor, db_name):
        try:
            cursor.execute('USE {}'.format(db_name))
        except mysql.connector.Error as err:
            if err.errno == errorcode.ER_BAD_DB_ERROR: # ER_BAD_DB_ERROR 未知数据库
                self.create_database(cursor, db_name)
                cursor.execute('USE {}'.format(db_name))
            else:
                print(err)
                exit(1)
 
    # 创建表-批量创建(如果表直接存在依赖关系,但是执行时未对传入的tables字典参数的项进行排序,可能无法创建成功)
    def create_table(self, cursor, tables):
        for table_name, table_ddl in tables.items():
            try:
                print("Creating table {}:".format(table_name), end='')
                cursor.execute(table_ddl)
            except mysql.connector.Error as err:
                if err.errno == errorcode.ER_TABLE_EXISTS_ERROR:
                    print("already exists.")
                else:
                    print(err.msg)
            else:
                print('OK')
 
    # 创建表
    def create_table(self, cursor, table_ddl):
        try:
            print('Result of creating table:', end='')
            cursor.execute(table_ddl)
        except mysql.connector.Error as err:
            if err.errno == errorcode.ER_TABLE_EXISTS_ERROR:
                print("already exists.")
            else:
                print(err.msg)
        else:
             print('OK')
 
    # 插入数据
    def insert_data(self, cursor, insert_ddl, insert_data):
        try:
            cursor.execute(insert_ddl, insert_data)
            print('insert data into table success')
        except mysql.connector.Error as err:
            print('insert data into table failed')
            print(err)
 
    # 查询数据
    def query_data(self, cursor, query_ddl, query_data=None):
        try:
            if query_data:
                cursor.execute(query_ddl, query_data)
            else:
                cursor.execute(query_ddl)
            for row in cursor:
                print(row)
        except mysql.connector.Error as err:
            print(err)
 
if __name__ == '__main__':
    db = GetDB('./dbconfig.conf')
    dbconn = db.get_conn()
    cursor = dbconn.cursor()
    DB_NAME = 'employees'
 
    TABLES = {}
    TABLES['employees'] = (
        "CREATE TABLE `employees` ("
        "  `emp_no` int(11) NOT NULL AUTO_INCREMENT,"
        "  `birth_date` date NOT NULL,"
        "  `member_name` varchar(14) NOT NULL,"
        "  `gender` enum('M','F') NOT NULL,"
        "  `hire_date` date NOT NULL,"
        "  PRIMARY KEY (`emp_no`)"
        ") ENGINE=InnoDB")
 
    TABLES['departments'] = (
        "CREATE TABLE `departments` ("
        "  `dept_no` int(11) NOT NULL,"
        "  `dept_name` varchar(40) NOT NULL,"
        "  PRIMARY KEY (`dept_no`), UNIQUE KEY `dept_name`(`dept_name`)"
        ") ENGINE=InnoDB")
 
    db.create_database(cursor, 'testdb')
 
    db.use_database(cursor, DB_NAME)
    #db.create_table(cursor, TABLES)
 
    print('creating table employees')
    db.create_table(cursor, TABLES['employees'])
    print('creating table departments')
    db.create_table(cursor, TABLES['departments'])
 
    tomorrow = datetime.now().date() + timedelta(days=1)
 
    add_employee = ("INSERT INTO employees "
                    "(member_name, hire_date, gender, birth_date) "
                    "VALUES (%s, %s, %s, %s)")
 
    add_departments = ("INSERT INTO departments "
                       "(dept_no, dept_name) "
                       "VALUES (%(dept_no)s, %(dept_name)s)")
 
    data_employee = ('Geert', tomorrow, 'M', date(1977, 6, 14))
 
    # Insert new employee
    db.insert_data(cursor, add_employee, data_employee)
 
    # Insert departments information
    emp_no = cursor.lastrowid
    data_departments = {
      'dept_no': emp_no,
      'dept_name': 'computer'+ str(emp_no)
    }
    db.insert_data(cursor, add_departments, data_departments)
 
    # 使插入数据操作生效
    try:
        dbconn.commit()
    except Exception as e:
        print(e)
        dbconn.rollback()
 
    query = ("SELECT member_name, hire_date FROM employees "
             "WHERE hire_date BETWEEN %s AND %s")
 
    hire_start = date(2015, 1, 1)
    hire_end = date(2016, 1, 10)
    db.query_data(cursor, query,(hire_start, hire_end))
 
    # 关闭游标
    cursor.close()
 
    # 关闭数据库连接
    dbconn.close()
 
注:其它操作和MYSQLdb类似,不再赘述,烦请参考文章:Python2.7操作Mariadb、Mysql数据库简介
 
运行结果:

 


参考连接:

http://dev.mysql.com/doc/connector-python/en/

http://dev.mysql.com/doc/connector-python/en/connector-python-examples.html

Python使用MySQLConnector/Python操作MySQL、MariaDB数据库的更多相关文章

  1. MySQL/MariaDB数据库的多表查询操作

    MySQL/MariaDB数据库的多表查询操作 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.单表查询小试牛刀 [root@node105.yinzhengjie.org.cn ...

  2. MySQL/MariaDB数据库的查询缓存优化

    MySQL/MariaDB数据库的查询缓存优化 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL架构 Connectors(MySQL对外提供的交互接口,API): ...

  3. MySQL/MariaDB数据库的触发器

    MySQL/MariaDB数据库的触发器 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.触发器概述 1>.什么是触发器 触发器的执行不是由程序调用,也不是由手工启动,而是 ...

  4. MySQL/MariaDB数据库的性能测试

      MySQL/MariaDB数据库的性能测试 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.数据库服务衡量指标 qps: query per second(每秒支持多少查询 ...

  5. MySQL/MariaDB数据库的MHA实现高可用实战

      MySQL/MariaDB数据库的MHA实现高可用实战 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL高可用常见的解决方案 1>.Multi-Master ...

  6. MySQL/MariaDB数据库的PROXY实现读写分离

    MySQL/MariaDB数据库的PROXY实现读写分离 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.ProxySQL概述 1>.各家互联网公司读写分离的解决方案 m ...

  7. MySQL/MariaDB数据库的复制加密

      MySQL/MariaDB数据库的复制加密 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL的安全问题 1>.基于SSL复制 在默认的主从复制过程或远程连接 ...

  8. MySQL/MariaDB数据库的半同步复制

      MySQL/MariaDB数据库的半同步复制 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL半同步复制概述 1>.MySQL默认的异步复制 默认情况下,M ...

  9. MySQL/MariaDB数据库的主主复制

      MySQL/MariaDB数据库的主主复制 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.主主复制概述 1>.什么是主主复制 所谓的主主复制,说白了就是两台节点互为 ...

  10. MySQL/MariaDB数据库的主从复制

     MySQL/MariaDB数据库的主从复制  作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL复制概述 1>.传统扩展方式 垂直扩展(也叫向上扩展,Sacle ...

随机推荐

  1. 解决 在 WINDOWS 下 同时安装 python2 python3 后 pip 错误

    再之前同时安装 python 后 只需把环境变量PATH 里面改为 PATH=C:\Python36-32\Scripts\;C:\Python36-32\;C:\Python27\;C:\Pytho ...

  2. centos clamav杀毒软件安装配置及查杀,没想到linux下病毒比windows还多!

    centos clamav杀毒软件安装配置及查杀,没想到linux下病毒比windows还多! 一.手动安装 1.下载(官网)    cd /soft     wget http://www.clam ...

  3. Ruby:Net::HTTP

    待续... Github上有几个关于Net::HTTP的使用例子:Ruby Net::HTTP cheat sheet Net::HTTP的官方文档 Ruby net/http example这篇文章 ...

  4. 一个对眼睛很好的vim 颜色主题

    地址:https://github.com/altercation/vim-colors-solarized 安装: $ cd vim-colors-solarized/colors $ mv sol ...

  5. ActiveMQ配置高可用性的方式

    当一个应用被部署于生产环境,灾备计划是非常重要的,以便从网络故障,硬件故障,软件故障或者电源故障中恢复.通过合理的配置ActiveMQ,可以解决上诉问题.最典型的配置方法是运行多个Broker,一旦某 ...

  6. github绑定自己的域名

    1.进入需要绑定域名的项目里面,然后新建一个文件CNAME,没有后缀的. 2.在文件里面输入你的域名,然后保存.github这边就完成了. 3.然后去你购买域名的网站,进入控制台,找到域名,然后域名解 ...

  7. 第k大的数

    问题描述:输入一组数,指定一个k,输出这组数里第k大的数. 一般这种题目,第一想法是把整个数组先排序后,再选取第k位的数.但是这样做实际上浪费了大量的时间在排序上,我们只是要求第k大的数,并非要把整个 ...

  8. mysql添加用户、修改权限,修改登录权限ip

    1.添加用户 1.1 登录MYSQL: @>mysql -u root -p @>密码 1.2 创建用户: 格式:grant select on 数据库.* to 用户名@登录主机 ide ...

  9. 【详解】JNI (Java Native Interface) (二)

    案例二:传递参数给C代码,并从其获取结果 注:这里传递的参数是基本类型的参数,在C代码中有直接的映射类型. 此案例所有生成的所有文件如下: (1)编写案例二的Java代码,如下: 这里我们定义了一个n ...

  10. Deep learning with Python 学习笔记(1)

    深度学习基础 Python 的 Keras 库来学习手写数字分类,将手写数字的灰度图像(28 像素 ×28 像素)划分到 10 个类别 中(0~9) 神经网络的核心组件是层(layer),它是一种数据 ...