欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

跟老齊學Python之使用Python查詢更新數(shù)據(jù)庫

 更新時間:2014年11月25日 16:33:22   投稿:hebedich  
前面我們講述了使用python操作數(shù)據(jù)庫,今天我們來更進一步,介紹下python查詢、更新數(shù)據(jù)庫的相關操作。有需要的小伙伴自己參考下吧。

回顧一下已有的戰(zhàn)果:(1)連接數(shù)據(jù)庫;(2)建立指針;(3)通過指針插入記錄;(4)提交將插入結果保存到數(shù)據(jù)庫。在交互模式中,先溫故,再知新。

復制代碼 代碼如下:

>>> #導入模塊
>>> import MySQLdb

>>> #連接數(shù)據(jù)庫
>>> conn = MySQLdb.connect(host="localhost",user="root",passwd="123123",db="qiwsirtest",port=3036,charset="utf8")

>>> #建立指針
>>> cur = conn.cursor()

>>> #插入記錄
>>> cur.execute("insert into users (username,password,email) values (%s,%s,%s)",("老齊","9988","qiwsir@gmail.com"))
1L

>>> #提交保存
>>> conn.commit()


如果看官跟我似的,有點強迫癥,總是想我得看到數(shù)據(jù)中有了,才放芳心呀。那就在進入到數(shù)據(jù)庫,看看。

復制代碼 代碼如下:

mysql> select * from users;
    +----+----------+----------+------------------+
    | id | username | password | email            |
    +----+----------+----------+------------------+
    |  1 | qiwsir   | 123123   | qiwsir@gmail.com |
    |  2 | python   | 123456   | python@gmail.com |
    |  3 | google   | 111222   | g@gmail.com      |
    |  4 | facebook | 222333   | f@face.book      |
    |  5 | github   | 333444   | git@hub.com      |
    |  6 | docker   | 444555   | doc@ker.com      |
    |  7 | 老齊     | 9988     | qiwsir@gmail.com |
    +----+----------+----------+------------------+
    7 rows in set (0.00 sec)

剛才溫故的時候,插入的那條記錄也赫然在目。不過這里特別提醒看官,我在前面建立這個數(shù)據(jù)庫和數(shù)據(jù)表的時候,就已經(jīng)設定好了字符編碼為utf8,所以,在現(xiàn)在看到的查詢結果中,可以顯示漢字。否則,就看到的是一堆你不懂的碼子了。如果看官遇到,請不要慌張,只需要修改字符編碼即可。怎么改?請google。網(wǎng)上很多。

溫故結束,開始知新。

查詢數(shù)據(jù)

在前面操作的基礎上,如果要從數(shù)據(jù)庫中查詢數(shù)據(jù),當然也可以用指針來操作了。

復制代碼 代碼如下:

>>> cur.execute("select * from users")   
7L

這說明從users表匯總查詢出來了7條記錄。但是,這似乎有點不友好,告訴我7條記錄查出來了,但是在哪里呢,看前面在'mysql>'下操作查詢命令的時候,一下就把7條記錄列出來了。怎么顯示python在這里的查詢結果呢?

原來,在指針實例中,還要用這樣的方法,才能實現(xiàn)上述想法:

fetchall(self):接收全部的返回結果行.
fetchmany(size=None):接收size條返回結果行.如果size的值大于返回的結果行的數(shù)量,則會返回cursor.arraysize條數(shù)據(jù).
fetchone():返回一條結果行.
scroll(value, mode='relative'):移動指針到某一行.如果mode='relative',則表示從當前所在行移動value條,如果mode='absolute',則表示從結果集的第一行移動value條.
按照這些規(guī)則,嘗試:

復制代碼 代碼如下:

>>> cur.execute("select * from users")   
7L
>>> lines = cur.fetchall()

到這里,還沒有看到什么,其實已經(jīng)將查詢到的記錄(把他們看做對象)賦值給變量lines了。如果要把它們顯示出來,就要用到曾經(jīng)學習過的循環(huán)語句了。

復制代碼 代碼如下:

>>> for line in lines:
...     print line
...
(1L, u'qiwsir', u'123123', u'qiwsir@gmail.com')
(2L, u'python', u'123456', u'python@gmail.com')
(3L, u'google', u'111222', u'g@gmail.com')
(4L, u'facebook', u'222333', u'f@face.book')
(5L, u'github', u'333444', u'git@hub.com')
(6L, u'docker', u'444555', u'doc@ker.com')
(7L, u'\u8001\u9f50', u'9988', u'qiwsir@gmail.com')

很好。果然是逐條顯示出來了。列位注意,第七條中的u'\u8001\u95f5',這里是漢字,只不過由于我的shell不能顯示罷了,不必驚慌,不必搭理它。

只想查出第一條,可以嗎?當然可以!看下面的:

復制代碼 代碼如下:

>>> cur.execute("select * from users where id=1")
1L
>>> line_first = cur.fetchone()     #只返回一條
>>> print line_first
(1L, u'qiwsir', u'123123', u'qiwsir@gmail.com')

為了對上述過程了解深入,做下面實驗:

復制代碼 代碼如下:

>>> cur.execute("select * from users")
7L
>>> print cur.fetchall()
((1L, u'qiwsir', u'123123', u'qiwsir@gmail.com'), (2L, u'python', u'123456', u'python@gmail.com'), (3L, u'google', u'111222', u'g@gmail.com'), (4L, u'facebook', u'222333', u'f@face.book'), (5L, u'github', u'333444', u'git@hub.com'), (6L, u'docker', u'444555', u'doc@ker.com'), (7L, u'\u8001\u9f50', u'9988', u'qiwsir@gmail.com'))

原來,用cur.execute()從數(shù)據(jù)庫查詢出來的東西,被“保存在了cur所能找到的某個地方”,要找出這些被保存的東西,需要用cur.fetchall()(或者fechone等),并且找出來之后,做為對象存在。從上面的實驗探討發(fā)現(xiàn),被保存的對象是一個tuple中,里面的每個元素,都是一個一個的tuple。因此,用for循環(huán)就可以一個一個拿出來了。

看官是否理解其內(nèi)涵了?

接著看,還有神奇的呢。

接著上面的操作,再打印一遍

復制代碼 代碼如下:

>>> print cur.fetchall()
()

暈了!怎么什么是空?不是說做為對象已經(jīng)存在了內(nèi)存中了嗎?難道這個內(nèi)存中的對象是一次有效嗎?

不要著急。

通過指針找出來的對象,在讀取的時候有一個特點,就是那個指針會移動。在第一次操作了print cur.fetchall()后,因為是將所有的都打印出來,指針就要從第一條移動到最后一條。當print結束之后,指針已經(jīng)在最后一條的后面了。接下來如果再次打印,就空了,最后一條后面沒有東西了。

下面還要實驗,檢驗上面所說:

復制代碼 代碼如下:

>>> cur.execute('select * from users')
7L
>>> print cur.fetchone()
(1L, u'qiwsir', u'123123', u'qiwsir@gmail.com')
>>> print cur.fetchone()
(2L, u'python', u'123456', u'python@gmail.com')
>>> print cur.fetchone()
(3L, u'google', u'111222', u'g@gmail.com')

這次我不一次全部打印出來了,而是一次打印一條,看官可以從結果中看出來,果然那個指針在一條一條向下移動呢。注意,我在這次實驗中,是重新運行了查詢語句。

那么,既然在操作存儲在內(nèi)存中的對象時候,指針會移動,能不能讓指針向上移動,或者移動到指定位置呢?這就是那個scroll()

復制代碼 代碼如下:

>>> cur.scroll(1)
>>> print cur.fetchone()
(5L, u'github', u'333444', u'git@hub.com')
>>> cur.scroll(-2)
>>> print cur.fetchone()
(4L, u'facebook', u'222333', u'f@face.book')

果然,這個函數(shù)能夠移動指針,不過請仔細觀察,上面的方式是讓指針相對與當前位置向上或者向下移動。即:

cur.scroll(n),或者,cur.scroll(n,"relative"):意思是相對當前位置向上或者向下移動,n為正數(shù),表示向下(向前),n為負數(shù),表示向上(向后)

還有一種方式,可以實現(xiàn)“絕對”移動,不是“相對”移動:增加一個參數(shù)"absolute"

特別提醒看官注意的是,在python中,序列對象是的順序是從0開始的。

復制代碼 代碼如下:

>>> cur.scroll(2,"absolute")    #回到序號是2,但指向第三條
>>> print cur.fetchone()        #打印,果然是
(3L, u'google', u'111222', u'g@gmail.com')

>>> cur.scroll(1,"absolute")
>>> print cur.fetchone()
(2L, u'python', u'123456', u'python@gmail.com')

>>> cur.scroll(0,"absolute")    #回到序號是0,即指向tuple的第一條
>>> print cur.fetchone()
(1L, u'qiwsir', u'123123', u'qiwsir@gmail.com')

至此,已經(jīng)熟悉了cur.fetchall()和cur.fetchone()以及cur.scroll()幾個方法,還有另外一個,接這上邊的操作,也就是指針在序號是1的位置,指向了tuple的第二條

復制代碼 代碼如下:

>>> cur.fetchmany(3)
((2L, u'python', u'123456', u'python@gmail.com'), (3L, u'google', u'111222', u'g@gmail.com'), (4L, u'facebook', u'222333', u'f@face.book'))

上面這個操作,就是實現(xiàn)了從當前位置(指針指向tuple的序號為1的位置,即第二條記錄)開始,含當前位置,向下列出3條記錄。

讀取數(shù)據(jù),好像有點啰嗦呀。細細琢磨,還是有道理的。你覺得呢?

不過,python總是能夠為我們著想的,它的指針提供了一個參數(shù),可以實現(xiàn)將讀取到的數(shù)據(jù)變成字典形式,這樣就提供了另外一種讀取方式了。

復制代碼 代碼如下:

>>> cur = conn.cursor(cursorclass=MySQLdb.cursors.DictCursor)
>>> cur.execute("select * from users")
7L
>>> cur.fetchall()
({'username': u'qiwsir', 'password': u'123123', 'id': 1L, 'email': u'qiwsir@gmail.com'}, {'username': u'mypython', 'password': u'123456', 'id': 2L, 'email': u'python@gmail.com'}, {'username': u'google', 'password': u'111222', 'id': 3L, 'email': u'g@gmail.com'}, {'username': u'facebook', 'password': u'222333', 'id': 4L, 'email': u'f@face.book'}, {'username': u'github', 'password': u'333444', 'id': 5L, 'email': u'git@hub.com'}, {'username': u'docker', 'password': u'444555', 'id': 6L, 'email': u'doc@ker.com'}, {'username': u'\u8001\u9f50', 'password': u'9988', 'id': 7L, 'email': u'qiwsir@gmail.com'})   

這樣,在元組里面的元素就是一個一個字典??梢赃@樣來操作這個對象:

復制代碼 代碼如下:

>>> cur.scroll(0,"absolute")
>>> for line in cur.fetchall():
...     print line["username"]
...
qiwsir
mypython
google
facebook
github
docker
老齊

根據(jù)字典對象的特點來讀取了“鍵-值”。

更新數(shù)據(jù)

經(jīng)過前面的操作,這個就比較簡單了,不過需要提醒的是,如果更新完畢,和插入數(shù)據(jù)一樣,都需要commit()來提交保存。

復制代碼 代碼如下:

>>> cur.execute("update users set username=%s where id=2",("mypython"))
1L
>>> cur.execute("select * from users where id=2")
1L
>>> cur.fetchone()
(2L, u'mypython', u'123456', u'python@gmail.com')

從操作中看出來了,已經(jīng)將數(shù)據(jù)庫中第二條的用戶名修改為mypython了,用的就是update語句。

不過,要真的實現(xiàn)在數(shù)據(jù)庫中更新,還要運行:

復制代碼 代碼如下:

>>> conn.commit()

這就大事完吉了。

相關文章

  • Python pandas 計算每行的增長率與累計增長率

    Python pandas 計算每行的增長率與累計增長率

    這篇文章主要介紹了Python pandas 計算每行的增長率與累計增長率,文章舉例詳細說明。需要的小伙伴可以參考一下
    2022-03-03
  • 深入解析PYTHON?虛擬機令人拍案叫絕的字節(jié)碼設計

    深入解析PYTHON?虛擬機令人拍案叫絕的字節(jié)碼設計

    這篇文章主要為大家介紹了PYTHON虛擬機中令人拍案叫絕的字節(jié)碼設計深入詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • python實現(xiàn)一組典型數(shù)據(jù)格式轉(zhuǎn)換

    python實現(xiàn)一組典型數(shù)據(jù)格式轉(zhuǎn)換

    這篇文章主要為大家詳細介紹了python實現(xiàn)一組典型數(shù)據(jù)格式轉(zhuǎn)換,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • 如何基于Python和Flask編寫Prometheus監(jiān)控

    如何基于Python和Flask編寫Prometheus監(jiān)控

    這篇文章主要介紹了如何基于Python和Flask編寫Prometheus監(jiān)控,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-11-11
  • Pytorch在NLP中的簡單應用詳解

    Pytorch在NLP中的簡單應用詳解

    今天小編就為大家分享一篇Pytorch在NLP中的簡單應用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • python2.7 安裝pip的方法步驟(管用)

    python2.7 安裝pip的方法步驟(管用)

    這篇文章主要介紹了python2.7 安裝pip的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • pytorch 一行代碼查看網(wǎng)絡參數(shù)總量的實現(xiàn)

    pytorch 一行代碼查看網(wǎng)絡參數(shù)總量的實現(xiàn)

    這篇文章主要介紹了pytorch實現(xiàn)一行代碼查看網(wǎng)絡參數(shù)總量的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-05-05
  • 基于Python實現(xiàn)將列表數(shù)據(jù)生成折線圖

    基于Python實現(xiàn)將列表數(shù)據(jù)生成折線圖

    這篇文章主要介紹了如何利用Python中的pandas庫和matplotlib庫,實現(xiàn)將列表數(shù)據(jù)生成折線圖,文中的示例代碼簡潔易懂,需要的可以參考一下
    2022-03-03
  • Python基礎之語法錯誤和異常詳解

    Python基礎之語法錯誤和異常詳解

    Python有兩種錯誤很容易辨認:語法錯誤和異常.本文就給大家詳細介紹一下Python錯誤和異常,對正在學習python的小伙伴們很有幫助哦,需要的朋友可以參考下
    2021-05-05
  • python 3.8 的anaconda下載方法

    python 3.8 的anaconda下載方法

    本文詳細介紹了如何下載和安裝帶有Python3.8的Anaconda發(fā)行版,包括Anaconda簡介、下載步驟、安裝指南以及驗證安裝結果,此外,還介紹了如何設置Python3.8作為默認版本并利用別名功能進行快捷切換,幫助讀者快速上手使用這一強大的數(shù)據(jù)科學工具,感興趣的朋友一起看看吧
    2025-02-02

最新評論