Python3.6实现连接mysql或mariadb的方法分析


Posted in Python onMay 18, 2018

本文实例讲述了Python3.6实现连接mysql或mariadb的方法。分享给大家供大家参考,具体如下:

python3.6的安装查看前面一篇文章https://3water.com/article/108938.htm

mysql或mariadb数据库的安装查看以前的相关文章,这里不再赘述

首先在mariadb数据库中创建相应的库和表:

MariaDB [(none)]> create database oracle default character set utf8 default collate utf8_general_ci;
Query OK, 1 row affected (0.00 sec)
MariaDB [oracle]> create table oracle_indexmonitor( index_name varchar(200) not null, ipaddress varchar(39) not null, tnsname varchar(100) not null, insert_time timestamp default current_timestamp, primary key(index_name) ) engine=InnoDB default charset=utf8; 
Query OK, 0 rows affected (0.01 sec)
MariaDB [oracle]> desc oracle_indexmonitor;
+-------------+--------------+------+-----+-------------------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------------+--------------+------+-----+-------------------+-------+
| index_name | varchar(200) | NO | PRI | NULL | |
| ipaddress | varchar(39) | NO | | NULL | |
| tnsname | varchar(100) | NO | | NULL | |
| insert_time | timestamp | NO | | CURRENT_TIMESTAMP | |
+-------------+--------------+------+-----+-------------------+-------+
4 rows in set (0.00 sec)

安装需要用到的模块pymysql:

[root@wadeson Python-3.6.1]# /usr/local/python36/bin/pip3 install PyMysql
Collecting PyMysql
Downloading PyMySQL-0.7.11-py2.py3-none-any.whl (78kB)
100% |¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?¨?| 81kB 87kB/s 
Installing collected packages: PyMysql
Successfully installed PyMysql-0.7.11

检测模块是否安装成功:

[root@wadeson Python-3.6.1]# python
Python 3.6.1 (default, Jul 13 2017, 15:41:38) 
[GCC 4.4.7 20120313 (Red Hat 4.4.7-18)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import pymysql
>>> exit()

然后编写py脚本:

[root@wadeson Python-3.6.1]# cd /root/tools/scripts/
[root@wadeson scripts]# vim connectmysql.py
#!/usr/bin/python
#coding=utf8
import pymysql
#连接数据库,host、账号、密码、库
db = pymysql.connect('localhost','root','redhat','oracle')
#创建游标使用的cursor方法
cursor = db.cursor()
#使用execute方法执行sql语句
cursor.execute('select version()')
#使用fetchone方法获取单条数据
data = cursor.fetchone()
print('Database version:%s' % data)
#关闭游标,并关闭数据库
cursor.close()
db.close()
[root@wadeson scripts]# python connectmysql.py 
Database version:5.5.55-MariaDB

note:

Python查询Mysql使用 fetchone() 方法获取单条数据, 使用fetchall() 方法获取多条数据。

fetchone(): 该方法获取下一个查询结果集。结果集是一个对象
fetchall(): 接收全部的返回结果行.
rowcount: 这是一个只读属性,并返回执行execute()方法后影响的行数。

note:如果使用以上方法安装报错:ssl模块不可用

那么可以使用编译安装:

wget https://pypi.python.org/packages/f5/d9/976c885396294bb1c4ca3d013fd2046496cde2efbb168e4f41dd12552dd9/PyMySQL-0.7.6.tar.gz#md5=d1353d9ad6e6668c3c463603b12cadb0
tar xf PyMySQL-0.7.6.tar.gz
cd PyMySQL-0.7.6
python setup.py build
python setup.py install

然后验证是否安装成功:

[root@oracle PyMySQL-0.7.6]# python 
Python 3.6.1 (default, Jul 13 2017, 14:31:18) 
[GCC 4.4.7 20120313 (Red Hat 4.4.7-17)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import pymysql
>>>

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
讲解Python中的递归函数
Apr 27 Python
在Python中使用__slots__方法的详细教程
Apr 28 Python
python爬虫之百度API调用方法
Jun 11 Python
python利用有道翻译实现"语言翻译器"的功能实例
Nov 14 Python
python实现生命游戏的示例代码(Game of Life)
Jan 24 Python
Python抓取聚划算商品分析页面获取商品信息并以XML格式保存到本地
Feb 23 Python
Python for i in range ()用法详解
Sep 18 Python
Python语言异常处理测试过程解析
Jan 08 Python
使用 Python 处理3万多条数据只要几秒钟
Jan 19 Python
python Socket网络编程实现C/S模式和P2P
Jun 22 Python
Python列表推导式实现代码实例
Sep 09 Python
python opencv常用图形绘制方法(线段、矩形、圆形、椭圆、文本)
Apr 12 Python
对python中使用requests模块参数编码的不同处理方法
May 18 #Python
Python3.6连接Oracle数据库的方法详解
May 18 #Python
python爬虫之模拟登陆csdn的实例代码
May 18 #Python
解决phantomjs截图失败,phantom.exit位置的问题
May 17 #Python
python自动截取需要区域,进行图像识别的方法
May 17 #Python
Python使用Phantomjs截屏网页的方法
May 17 #Python
Python 实现网页自动截图的示例讲解
May 17 #Python
You might like
世界收音机发展史
2021/03/01 无线电
解析二进制流接口应用实例 pack、unpack、ord 函数使用方法
2013/06/18 PHP
phpmyadmin打开很慢的解决方法
2014/04/21 PHP
php+mysql大量用户登录解决方案分析
2014/12/29 PHP
PHP表单提交后引号前自动加反斜杠的原因及三种办法关闭php魔术引号
2015/09/30 PHP
php 解决扫描二维码下载跳转问题
2017/01/13 PHP
thinkPHP框架可添加js事件的分页类customPage.class.php完整实例
2017/03/16 PHP
js关于字符长度限制的问题示例探讨
2014/01/24 Javascript
js调试系列 源码定位与调试[基础篇]
2014/06/18 Javascript
JavaScript模拟实现键盘打字效果
2015/06/29 Javascript
js确认框confirm()用法实例详解
2016/01/07 Javascript
AngularJS基础 ng-readonly 指令简单示例
2016/08/02 Javascript
React组件中的this的具体使用
2018/02/28 Javascript
微信小程序仿知乎实现评论留言功能
2018/11/28 Javascript
vue iview多张图片大图预览、缩放翻转
2019/07/13 Javascript
vue中使用v-model完成组件间的通信
2019/08/22 Javascript
vue 解决无法对未定义的值,空值或基元值设置反应属性报错问题
2020/07/31 Javascript
python基础教程之基本内置数据类型介绍
2014/02/20 Python
Python中使用SAX解析xml实例
2014/11/21 Python
Python元组操作实例分析【创建、赋值、更新、删除等】
2017/07/24 Python
python使用itchat实现手机控制电脑
2018/02/22 Python
解决pycharm 安装numpy失败的问题
2019/12/05 Python
Django用数据库表反向生成models类知识点详解
2020/03/25 Python
html5 Canvas画图教程(4)—未闭合的路径及渐变色的填充方法
2013/01/09 HTML / CSS
Notino芬兰:购买香水和化妆品
2019/04/15 全球购物
研发工程师的岗位职责
2013/11/18 职场文书
食堂员工工作职责
2013/12/18 职场文书
给酒店员工的表扬信
2014/01/11 职场文书
优秀教师申报材料
2014/12/16 职场文书
办公室个人总结
2015/02/28 职场文书
2015年度服装销售工作总结
2015/03/31 职场文书
考试后的感想
2015/08/07 职场文书
七年级作文之环保作文
2019/10/17 职场文书
Python如何把不同类型数据的json序列化
2021/04/30 Python
Python中基础数据类型 set集合知识点总结
2021/08/02 Python
spring IOC容器的Bean管理XML自动装配过程
2022/05/30 Java/Android