Python ORM框架SQLAlchemy學(xué)習(xí)筆記之映射類(lèi)使用實(shí)例和Session會(huì)話介紹
1. 創(chuàng)建映射類(lèi)的實(shí)例(Instance)
前面介紹了如何將數(shù)據(jù)庫(kù)實(shí)體表映射到Python類(lèi)上,下面我們可以創(chuàng)建這個(gè)類(lèi)的一個(gè)實(shí)例(Instance),我們還是以前一篇文章的User類(lèi)為例,讓我們創(chuàng)建User對(duì)象:
>>> ed_user = User('ed', 'Ed Jones', 'edspassword')
>>> ed_user.name
'ed'
>>> ed_user.password
'edspassword'
>>> str(ed_user.id)
'None'
和普通的Python類(lèi)一樣實(shí)例化,大家可能會(huì)問(wèn)為什么ed_user.id會(huì)是None值,首先id這個(gè)屬性沒(méi)有通過(guò)__init__()構(gòu)造方法初始化,所以默認(rèn)會(huì)因?yàn)橄惹岸x的ORM的id列(Column)而產(chǎn)生一個(gè)None值,在默認(rèn)情況下,ORM會(huì)為所有被映射的表列創(chuàng)建類(lèi)屬性,這些屬性是通過(guò)Python語(yǔ)言中描述符(Descriptors)機(jī)制來(lái)實(shí)現(xiàn)的。所以這些屬性的使用會(huì)包含一些額外的行為,包括跟蹤修改,或者當(dāng)需要時(shí)自動(dòng)從數(shù)據(jù)庫(kù)加載新的數(shù)據(jù),也就是說(shuō)我們?cè)谑褂眠@些屬性時(shí),包括修改或者讀取,都會(huì)觸發(fā)ORM內(nèi)部的一系列動(dòng)作。
等等,你還沒(méi)有說(shuō)明白為什么id這個(gè)屬性會(huì)為None值呢。呵呵,其實(shí)我們現(xiàn)在并沒(méi)有將數(shù)據(jù)插入數(shù)據(jù)庫(kù),一般主鍵這個(gè)屬性會(huì)在插入數(shù)據(jù)庫(kù)時(shí)自動(dòng)產(chǎn)生一個(gè)不重復(fù)的值以保證唯一性。由于我們沒(méi)有對(duì)對(duì)象實(shí)行持久化(Persist) (所謂的持久化就是把對(duì)象數(shù)據(jù)按照映射關(guān)系存儲(chǔ)入數(shù)據(jù)庫(kù)里) 所以這里id值為None。別著急,稍后當(dāng)我們介紹將數(shù)據(jù)持久化后你就可以看到一個(gè)新的自動(dòng)產(chǎn)生的id了。
接下來(lái)小偷懶一下,介紹一個(gè)偷懶的技巧:-)
假如我們不定義映射類(lèi)的構(gòu)造方法__init__()會(huì)帶來(lái)什么不良影響嗎?完全不會(huì),SQLAlchemy為我們考慮到這點(diǎn),假如我們偷懶將先前的User類(lèi)定義成這樣:
class User(Base):
__tablename__ = 'users'
id = Column(Integer, primary_key=True)
name = Column(String)
fullname = Column(String)
password = Column(String)
由于User繼承自Base (Base定義見(jiàn)上一篇文章),所以受到Declarative系統(tǒng)的管理,Declarative系統(tǒng)發(fā)現(xiàn)這個(gè)類(lèi)缺少構(gòu)造方法,于是很友善的給我們補(bǔ)上了一個(gè)構(gòu)造方法,當(dāng)然其提供的構(gòu)造方法則不能像我們自己定義的構(gòu)造方法那樣使用基于位置的參數(shù)訪問(wèn),建議使用基于鍵的參數(shù)訪問(wèn)方式,包括我們所有用Column定義映射的列,比如如下方式:
u1 = User(name='ed', fullname='Ed Jones', password='foobar')
id也可以傳入,通常意義上這類(lèi)主鍵由系統(tǒng)自動(dòng)維護(hù),我們無(wú)需為其賦值。
2. 創(chuàng)建并使用會(huì)話(Session)
到這里可謂是“萬(wàn)事俱備,只欠東風(fēng)了”,用官方文檔的話說(shuō)“我們現(xiàn)在已經(jīng)準(zhǔn)備好和數(shù)據(jù)庫(kù)‘交談'了” (We're now ready to start talking to the database)。ORM的操作句柄(Handle)被稱(chēng)為會(huì)話(Session)。為了使用會(huì)話,我們需要先配置它,配置Session的代碼語(yǔ)句應(yīng)該和create_engine()創(chuàng)建引擎的代碼語(yǔ)句在一個(gè)代碼級(jí)別上(放在一起就行了)。
比如我們利用create_engine()先建立起引擎名字為engine(關(guān)于引擎的建立代碼可以參考我第一篇文章),然后利用sessionmaker()工廠函數(shù)建立起Session類(lèi),同時(shí)綁定我們現(xiàn)有的引擎,比如代碼如下:
>>> from sqlalchemy.orm import sessionmaker
>>> Session = sessionmaker(bind=engine)
假如我們創(chuàng)建Session的代碼與創(chuàng)建引擎的代碼不在一個(gè)級(jí)別上呢,比如先sessionmaker()一個(gè)Session類(lèi),然后才用create_engine()創(chuàng)建了引擎,那么我們還有機(jī)會(huì)將Session和引擎綁定到一起嗎?當(dāng)然可以,我們可以利用Session類(lèi)的configure方法來(lái)配置引擎綁定,比如這樣的:
Session = sessionmaker()
# engine = create_engine(...) 創(chuàng)建引擎
Session.configure(bind=engine) # 到這里engine應(yīng)該已經(jīng)創(chuàng)建
到這里通過(guò)sessionmaker()工廠創(chuàng)造出的Session類(lèi)應(yīng)該綁定了我們先前創(chuàng)建的Engine了,但是會(huì)話還沒(méi)有真正開(kāi)始,要開(kāi)始會(huì)話我們需要實(shí)例化這個(gè)Session類(lèi):
>>> session = Session()
到這里session就獲取了由Engine維護(hù)的數(shù)據(jù)庫(kù)連接池,并且會(huì)維持內(nèi)存中的映射數(shù)據(jù)直到提交(commit)更改或者關(guān)閉會(huì)話對(duì)象。
到這里會(huì)話的建立就講解完了,接下來(lái)會(huì)講解真正的ORM數(shù)據(jù)庫(kù)查詢部分,歡迎關(guān)注!
- python中requests模擬登錄的三種方式(攜帶cookie/session進(jìn)行請(qǐng)求網(wǎng)站)
- Python處理session的方法整理
- python使用requests.session模擬登錄
- python3+requests接口自動(dòng)化session操作方法
- Python爬蟲(chóng)番外篇之Cookie和Session詳解
- python中requests庫(kù)session對(duì)象的妙用詳解
- 剖析Python的Tornado框架中session支持的實(shí)現(xiàn)代碼
- 在Python的Django框架的視圖中使用Session的方法
- Python3使用Selenium獲取session和token方法詳解
相關(guān)文章
Keras搭建分類(lèi)網(wǎng)絡(luò)平臺(tái)VGG16?MobileNet?ResNet50
這篇文章主要為大家介紹了Keras搭建分類(lèi)網(wǎng)絡(luò)平臺(tái)VGG16?MobileNet?ResNet50,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05python中opencv圖像疊加、圖像融合、按位操作的具體實(shí)現(xiàn)
opencv圖像操作可以更好更快的方便我們處理圖片,本文主要介紹了圖像疊加、圖像融合、按位操作,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07Python 統(tǒng)計(jì)位數(shù)為偶數(shù)的數(shù)字代碼詳解
這篇文章主要介紹了Python 統(tǒng)計(jì)位數(shù)為偶數(shù)的數(shù)字,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03利用Python實(shí)現(xiàn)去重聚合Excel數(shù)據(jù)并對(duì)比兩份數(shù)據(jù)的差異
在數(shù)據(jù)處理過(guò)程中,常常需要將多個(gè)數(shù)據(jù)表進(jìn)行合并,并進(jìn)行比對(duì),以便找出數(shù)據(jù)的差異和共同之處,本文將介紹如何使用 Pandas 庫(kù)對(duì)兩個(gè) Excel 數(shù)據(jù)表進(jìn)行合并與比對(duì),需要的可以參考下2023-11-11python 遺傳算法求函數(shù)極值的實(shí)現(xiàn)代碼
今天小編就為大家分享一篇python 遺傳算法求函數(shù)極值的實(shí)現(xiàn)代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-02-02Python中使用Queue和Condition進(jìn)行線程同步的方法
這篇文章主要介紹了Python中使用Queue模塊和Condition對(duì)象進(jìn)行線程同步的方法,配合threading模塊下的線程編程進(jìn)行操作的實(shí)例,需要的朋友可以參考下2016-01-01Python使用pandas處理CSV文件的實(shí)例講解
今天小編就為大家分享一篇Python使用pandas處理CSV文件的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-06-06Python實(shí)現(xiàn)處理逆波蘭表達(dá)式示例
這篇文章主要介紹了Python實(shí)現(xiàn)處理逆波蘭表達(dá)式操作,結(jié)合實(shí)例形式分析了逆波蘭表達(dá)式的概念、原理及Python針對(duì)逆波蘭表達(dá)式的定義與計(jì)算相關(guān)操作技巧,需要的朋友可以參考下2018-07-07