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中的yield函数的用法
Apr 03 Python
解决uWSGI的编码问题详解
Mar 24 Python
python实现的正则表达式功能入门教程【经典】
Jun 05 Python
python3实现TCP协议的简单服务器和客户端案例(分享)
Jun 14 Python
CentOS下使用yum安装python-pip失败的完美解决方法
Aug 16 Python
Python切片操作深入详解
Jul 27 Python
Python I/O与进程的详细讲解
Mar 08 Python
python实现视频分帧效果
May 31 Python
python实现按行分割文件
Jul 22 Python
TensorFlow命名空间和TensorBoard图节点实例
Jan 23 Python
Python基于pyecharts实现关联图绘制
Mar 27 Python
详解python定时简单爬取网页新闻存入数据库并发送邮件
Nov 27 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
PHP多线程抓取网页实现代码
2010/07/22 PHP
PHP的PDO操作简单示例
2016/03/30 PHP
PHP实现对图片的反色处理功能【测试可用】
2018/02/01 PHP
Track Image Loading效果代码分析
2007/08/13 Javascript
JavaScript CSS修改学习第一章 查找位置
2010/02/19 Javascript
如何防止回车(enter)键提交表单
2014/05/11 Javascript
JavaScript中的立即执行函数表达式介绍
2015/03/15 Javascript
js动态生成form 并用ajax方式提交的实现方法
2016/09/09 Javascript
将JSON字符串转换成Map对象的方法
2016/11/30 Javascript
微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(二)
2017/05/11 Javascript
JavaScript数据类型和变量_动力节点Java学院整理
2017/06/26 Javascript
微信小程序实现图片压缩功能
2018/01/26 Javascript
前端axios下载excel文件(二进制)的处理方法
2018/07/31 Javascript
jQuery实现动态添加和删除input框实例代码
2019/03/26 jQuery
[02:27]刀塔重生降临
2015/10/14 DOTA
[01:38]完美世界DOTA2联赛(PWL)宣传片:第一站
2020/10/26 DOTA
Python模拟百度登录实例详解
2016/01/20 Python
Python3解决棋盘覆盖问题的方法示例
2017/12/07 Python
Pandas中DataFrame基本函数整理(小结)
2020/07/20 Python
python中pdb模块实例用法
2021/01/15 Python
Bally巴利英国官网:经典瑞士鞋履、手袋及配饰奢侈品牌
2018/05/07 全球购物
美国知名眼镜网站:Target Optical
2020/04/04 全球购物
Java中有几种方法可以实现一个线程?用什么关键字修饰同步方法?stop()和suspend()方法为何不推荐使用?
2015/08/04 面试题
精选干货:Java精选笔试题附答案
2014/01/18 面试题
新学期开学寄语
2014/01/18 职场文书
十佳大学生事迹材料
2014/01/29 职场文书
房地产财务部员工岗位职责
2014/03/12 职场文书
弘扬职业精神演讲稿
2014/03/20 职场文书
药学职务聘任书
2014/03/29 职场文书
党校毕业心得体会
2014/09/13 职场文书
党员作风建设自查报告
2014/10/23 职场文书
12.4全国法制宣传日活动总结
2014/11/01 职场文书
大学生学年个人总结
2015/02/15 职场文书
我的兄弟姐妹观后感
2015/06/15 职场文书
签证工作证明模板
2015/06/15 职场文书
十大动画制作软件,Adobe产品上榜两款,第一是行业标准软件
2022/03/18 杂记