1. 安裝MySQLdb.從網站下載Mysql for python 的package 注意有32位和64位之分.
2. 安裝完成以後從Python IDLE 導入MySQLdb
3. 新建一個數據庫鏈接:
>>>conn =MySQLdb.connect(host = '127.0.0.1',user= 'root',passwd='123456',db='test',port=3306,charset='utf8')
4. 建立遊標:
5. 執行插入單條數據命令
>>>cur.execute("insert into msg (title,name,content) values ('python','zz','test mysql insert')")
>>>conn.commit() #須要提交事務插入纔會生效.
6. 利用參數插入多條數據命令
>>>sql = "insert into msg (title,name,content) values (%s,%s,%s)" #定義一個sql語句
>>>cur.executemany(sql,[('title01','name01','content01'),('title02','name02','content02')])
2L
>>>conn.commit()
>>>
7. 利用 for 循環拼接sql命令插入多條數據.
>>>sql = "insert into msg (title,name,content) values"
>>>for i in range (100):
>>> sql += "('id" + str(i) + "'," + "'name" + str(i) + "'," + "'content" + str(i) + "'),"
>>>sql = sql[:-1] #利用切片將最後的"," 刪除.
>>>cur.execute(sql)
103L
>>>conn.commit()
>>>
8. 執行刪除命令
>>>cur.execute("delete from msg where title = 'title02' ")
1L
>>>conn.commit()
>>>
9. 執行更改命令
>>>cur.execute("update msg set title='changedTitle' where title='title01'")
1L
>>>conn.commit()
>>>
10. 執行查詢命令
>>>cur.execute("
select * from msg")
3L #返回記錄條數
>>>
python的查詢語句並不會返回數據庫中存取的實際值, 僅返回得到的記錄條數, 那麼想要得到數據庫中的值該怎麼作呢?
咱們須要用到遊標的fetch.
11. 利用fetchone()得到一條記錄.該條記錄是當前遊標所在行的下一行數據.
>>>cur.fetchone()
(1L, 'title01', 'name01', 'content01')
12. 利用fetchmany(size=num) 獲取多條記錄.
>>>cur.fetchmany(size=5)
((2L, 'python', 'ChenYL', 'insert content'), (3L, 'py03', 'name03', 'content03'), (4L, 'py04', 'name04', 'content04'), (5L, 'id0', 'name0', 'content0'), (7L, 'id2', 'name2', 'content2'))
>>>
Note: 此處若查詢數據多於size參數則獲取和size參數相同的記錄條數, 若查詢數據記錄少於size參數的值,則只顯示查詢到的數據記錄條數.
13. 利用fetchall()獲取從遊標位置下一行開始直到查詢記錄結束的所有記錄.
>>>cur.fetchall()
105L
>>>
14. 利用scroll()移動遊標
>>>cur.scroll(1,mode="absolute")
>>>
Note: 當mode爲absolute時遊標走到表中的第一個參數行(若第一個參數爲1,則走到表中第一行),次數用fetchone()會取到第二行.
當mode爲relative是,此時遊標會往下走一行, 假如遊標在第三行, scroll以後會走到第四行.
15. 數據庫使用完以後記得關閉遊標. 關閉數據庫鏈接.
>>>cur.close()
>>>conn.close