Python使用MySQLConnector/Python操作MySQL、MariaDB数据库
使用MySQL Connector/Python操作MySQL、MariaDB数据库
by:授客 QQ:1033553122
因目前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数据库的更多相关文章
- MySQL/MariaDB数据库的多表查询操作
MySQL/MariaDB数据库的多表查询操作 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.单表查询小试牛刀 [root@node105.yinzhengjie.org.cn ...
- MySQL/MariaDB数据库的查询缓存优化
MySQL/MariaDB数据库的查询缓存优化 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL架构 Connectors(MySQL对外提供的交互接口,API): ...
- MySQL/MariaDB数据库的触发器
MySQL/MariaDB数据库的触发器 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.触发器概述 1>.什么是触发器 触发器的执行不是由程序调用,也不是由手工启动,而是 ...
- MySQL/MariaDB数据库的性能测试
MySQL/MariaDB数据库的性能测试 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.数据库服务衡量指标 qps: query per second(每秒支持多少查询 ...
- MySQL/MariaDB数据库的MHA实现高可用实战
MySQL/MariaDB数据库的MHA实现高可用实战 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL高可用常见的解决方案 1>.Multi-Master ...
- MySQL/MariaDB数据库的PROXY实现读写分离
MySQL/MariaDB数据库的PROXY实现读写分离 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.ProxySQL概述 1>.各家互联网公司读写分离的解决方案 m ...
- MySQL/MariaDB数据库的复制加密
MySQL/MariaDB数据库的复制加密 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL的安全问题 1>.基于SSL复制 在默认的主从复制过程或远程连接 ...
- MySQL/MariaDB数据库的半同步复制
MySQL/MariaDB数据库的半同步复制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL半同步复制概述 1>.MySQL默认的异步复制 默认情况下,M ...
- MySQL/MariaDB数据库的主主复制
MySQL/MariaDB数据库的主主复制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.主主复制概述 1>.什么是主主复制 所谓的主主复制,说白了就是两台节点互为 ...
- MySQL/MariaDB数据库的主从复制
MySQL/MariaDB数据库的主从复制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL复制概述 1>.传统扩展方式 垂直扩展(也叫向上扩展,Sacle ...
随机推荐
- 解决SecureCRT/Xshell无法以root用户连接Ubuntu
首先执行命令ps -e | grep ssh .查看是否有ssh进程运行. 确认没有ssh运行,且系统未安装openssh. 然后在系统终端界面内输入apt-get update命令. (确保系统 ...
- keytool和openssl生成的证书转换
keytool和openssl生成的证书转换 keytool生成证书示例 生成私钥+证书: keytool -genkey -alias client -keysize 2048 -validity ...
- Fragment中启动一个新的Activity
最近遇到一个小问题,就是我在主界面中用的是Fragment,其中四个Fragment,然后打算在其中一个里边,写一个TextView(准确地说是Linearout)的单击事件,然后跳转到另外一个Act ...
- Spring学习--Spring事务相关速记
数据库事务 事务特性: 原子性,事务是不可分割的最小工作单元,事务内的操作要么全做,要么全不做 一致性,在事务执行前数据库的数据处于正确的状态,而事务执行完成后数据库的数据还是处于正确的状态 隔离性, ...
- 【转载】CentOS中crontab定时计划任务的使用
转载自:http://blog.csdn.net/testcs_dn/article/details/48780971 概述 利用“任务计划”,可以将任何脚本.程序或文档安排在某个最方便的时间运行.通 ...
- NIO的Buffer&Channel&Selector
java的NIO和AIO Buffer position.limit.capacity 初始化 Buffer 填充 Buffer 提取 Buffer 中的值 mark() & reset() ...
- SpringBoot入门 (十一) 数据校验
本文记录学习在SpringBoot中做数据校验. 一 什么是数据校验 数据校验就是在应用程序中,对输入进来得数据做语义分析判断,阻挡不符合规则得数据,放行符合规则得数据,以确保被保存得数据符合我们得数 ...
- 利用https实现站点的访问
简介 它是由Netscape开发并内置于其浏览器中,用于对数据进行压缩和解压操作,并返回网络上传送回的结果.HTTPS实际上应用了Netscape的安 全套接字层(SSL)作为HTTP应用层的子层.( ...
- Git学习笔记3
git checkout 命令git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,这里有两种情况: 一种是readme.txt自修改后还没有 ...
- 分布式理论(一) —— CAP 定理
目录: 什么是 CAP 定理 为什么只能 3 选 2 能不能解决 3 选 2 的问题 引用 1. 什么是 CAP 定理 2000 年的时候,Eric Brewer 教授提出了 CAP 猜想,2年后,被 ...