利用Python訪問Mysql資料庫

來源:互聯網
上載者:User

標籤:

  首先要明確一點,我們在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資料庫

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.