標籤:
首先要明確一點,我們在Python中需要通過第三方庫才能訪問Mysql。
有這樣幾種方式:Mysql-python(即MySQLdb)、pymysql、mysql-connector。Mysql-python是用C寫的,速度最快,而後兩者是用純python寫的,相對來說速度慢一點。可惜的是Mysql-python只支援到python 2.7,對python 3.X都沒有支援。如果你用的是python3,就用不了Mysql-python了。本文章使用的是python 3.4,用的第三方庫是pymysql。
Pymysql的安裝
安裝好pip之後。在CMD中輸入命令pip install pymysql即可安裝。有關於pip的安裝和使用請自行百度。
安裝好pymysql後,其使用跟一般的第三方庫一樣,需要事先import,下面我直接給一個例子,大家可以從IDLE中實驗。
>>> import pymysql>>> conn=pymysql.connect(host=‘localhost‘,user=‘root‘,passwd=‘password‘,charset=‘utf8‘,port=3306)
#port一般都是3306,charset要寫utf8,不然可能會出現亂碼>>> cur=conn.cursor()
#查看有哪些資料庫>>> cur.execute(‘show databases‘)9>>> databases=[]>>> for i in cur: databases.append(i)>>> databases[(‘information_schema‘,), (‘firstdb‘,), (‘hive‘,), (‘jeesite‘,), (‘mysql‘,), (‘school‘,), (‘test‘,), (‘test1‘,), (‘test2015‘,)]>>> conn.select_db(‘test‘)>>> cur.execute(‘show tables‘)7>>> tables_list=cur.fetchall()>>> tables_list((‘user‘,), (‘user2‘,), (‘user3‘,), (‘user4‘,), (‘user5‘,), (‘user6‘,), (‘user7‘,))>>> cur.execute(‘select * from user‘)7>>> user_select_result=cur.fetchall()>>> user_select_result((‘1‘, ‘Michael‘), (‘11‘, ‘ozil‘), (‘12‘, ‘Giroud‘), (‘2‘, ‘Henry‘), (‘Alexis‘, ‘17‘), (‘Ramsey‘, ‘16‘), (‘Walcott‘, ‘14‘))>>> cur.execute(‘select * from user‘)7>>> user_select_result=cur.fetchone()>>> user_select_result(‘1‘, ‘Michael‘)>>> cur.execute(‘select * from user‘)7>>> user_select_result=cur.fetchmany(4)>>> user_select_result((‘1‘, ‘Michael‘), (‘11‘, ‘ozil‘), (‘12‘, ‘Giroud‘), (‘2‘, ‘Henry‘))>>> insert_value=(‘3‘,‘gibbs‘)>>> cur.execute(‘insert into user(id,name) values(%s,%s)‘,insert_value)1>>> cur.execute(‘select * from user‘)8>>> user_select_result=cur.fetchall()>>> user_select_result((‘1‘, ‘Michael‘), (‘11‘, ‘ozil‘), (‘12‘, ‘Giroud‘), (‘2‘, ‘Henry‘), (‘3‘, ‘gibbs‘), (‘Alexis‘, ‘17‘), (‘Ramsey‘, ‘16‘), (‘Walcott‘, ‘14‘))insert_value_list=[(‘22‘,‘debucy‘),(‘33‘,‘cech‘)]>>> cur.executemany(‘insert into user(id,name) values(%s,%s)‘,insert_value_list)2>>> cur.execute(‘select * from user‘)10>>> user_select_result=cur.fetchall()>>> user_select_result((‘1‘, ‘Michael‘), (‘11‘, ‘ozil‘), (‘12‘, ‘Giroud‘), (‘2‘, ‘Henry‘), (‘22‘, ‘debucy‘), (‘3‘, ‘gibbs‘), (‘33‘, ‘cech‘), (‘Alexis‘, ‘17‘), (‘Ramsey‘, ‘16‘), (‘Walcott‘, ‘14‘))>>> conn.commit()>>> cur.execute(‘update user set name="Ozil" where id="11"‘)1>>> user_select_result=cur.fetchall()>>> user_select_result()>>> cur.execute(‘select * from user‘)10>>> user_select_result=cur.fetchall()>>> user_select_result((‘1‘, ‘Michael‘), (‘11‘, ‘Ozil‘), (‘12‘, ‘Giroud‘), (‘2‘, ‘Henry‘), (‘22‘, ‘debucy‘), (‘3‘, ‘gibbs‘), (‘33‘, ‘cech‘), (‘Alexis‘, ‘17‘), (‘Ramsey‘, ‘16‘), (‘Walcott‘, ‘14‘))
#修改後一定要comiit,不然刪除、更新、添加的資料都不會被寫進資料庫中。>>> conn.commit()>>> cur.close()>>> conn.close()
利用Python訪問Mysql資料庫