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

作者:wadeson 时间:2024-01-26 19:46:36 

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

python3.6的安装查看前面一篇文章https://www.jb51.net/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程序设计有所帮助。

来源:http://www.cnblogs.com/jsonhc/p/7161032.html

标签:Python,mysql,mariadb
0
投稿

猜你喜欢

  • ORACLE 最大连接数的问题

    2009-07-23 14:27:00
  • 学习ASP.NET八天入门:第四天

    2007-08-07 13:40:00
  • pycharm如何使用anaconda中的各种包(操作步骤)

    2021-10-18 05:35:11
  • Python爬虫实现抓取电影网站信息并入库

    2023-12-25 02:42:32
  • python之线程通过信号pyqtSignal刷新ui的方法

    2022-01-03 22:28:45
  • python数据可视化plt库实例详解

    2022-11-30 21:23:28
  • 最强大最好最全的javascript 验证表单的例子

    2010-03-14 11:26:00
  • python 实现任务管理清单案例

    2023-09-01 04:59:17
  • 对MySQL几种联合查询的通俗解释

    2024-01-18 17:44:40
  • Web设计色彩速查表

    2009-12-21 16:24:00
  • 使用uni-app开发微信小程序的实现

    2024-05-13 09:10:42
  • 如何将HTML字符转换为DOM节点并动态添加到文档中详解

    2023-08-23 12:26:39
  • 使用IDEA回滚某次提交的代码步骤

    2023-06-21 03:15:28
  • 详解Python迭代和迭代器

    2023-04-30 23:31:13
  • Python3使用PyQt5制作简单的画板/手写板实例

    2022-01-11 15:21:30
  • 了解一下python内建模块collections

    2022-03-19 08:32:37
  • python中for用来遍历range函数的方法

    2022-01-28 03:04:53
  • JavaScript 扩展运算符用法实例小结【基于ES6】

    2024-04-22 13:06:03
  • python私有属性和方法实例分析

    2023-11-21 06:16:13
  • Python+OpenCV之图像轮廓详解

    2023-08-10 18:59:42
  • asp之家 网络编程 m.aspxhome.com