本文實例講述了Python3.6實現連接mysql或mariadb的方法。分享給大家供大家參考,具體如下:
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 PyMysqlCollecting PyMysqlDownloading PyMySQL-0.7.11-py2.py3-none-any.whl (78kB)100% |¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€¨€| 81kB 87kB/s Installing collected packages: PyMysqlSuccessfully installed PyMysql-0.7.11
檢測模塊是否安裝成功:
[root@wadeson Python-3.6.1]# pythonPython 3.6.1 (default, Jul 13 2017, 15:41:38) [GCC 4.4.7 20120313 (Red Hat 4.4.7-18)] on linuxType "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=utf8import 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=d1353d9ad6e6668c3c463603b12cadb0tar xf PyMySQL-0.7.6.tar.gzcd PyMySQL-0.7.6python setup.py buildpython 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 linuxType "help", "copyright", "credits" or "license" for more information.>>> import pymysql>>>
希望本文所述對大家Python程序設計有所幫助。
新聞熱點
疑難解答