python訪問(wèn)數(shù)據(jù)庫(kù)sqlalchemy中的query方法

python訪問(wèn)數(shù)據(jù)庫(kù)sqlalchemy中的query方法

ID:34725484

大?。?6.18 KB

頁(yè)數(shù):5頁(yè)

時(shí)間:2019-03-10

python訪問(wèn)數(shù)據(jù)庫(kù)sqlalchemy中的query方法_第1頁(yè)
python訪問(wèn)數(shù)據(jù)庫(kù)sqlalchemy中的query方法_第2頁(yè)
python訪問(wèn)數(shù)據(jù)庫(kù)sqlalchemy中的query方法_第3頁(yè)
python訪問(wèn)數(shù)據(jù)庫(kù)sqlalchemy中的query方法_第4頁(yè)
python訪問(wèn)數(shù)據(jù)庫(kù)sqlalchemy中的query方法_第5頁(yè)
資源描述:

《python訪問(wèn)數(shù)據(jù)庫(kù)sqlalchemy中的query方法》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在工程資料-天天文庫(kù)

1、SQLAlchemy中的Query方法在SQLAlchemy中執(zhí)行查詢是通過(guò)session對(duì)象的query方法完成的。query方法非常靈活,你可以根據(jù)需要使用不同的查詢方式查找數(shù)據(jù),下面一一舉例。1.直接通過(guò)映射類查找:#Queryinguserinstanceforinstanceinsession.query(User).order_by(User.id):printinstance.name,instance.fullname這種方法只要在query方法中,將映射類作為參數(shù),就可以查詢出這個(gè)映射類代表的數(shù)據(jù)庫(kù)表

2、中的數(shù)據(jù)。其相當(dāng)于下面的SQL語(yǔ)句:SELECTusers.idASusers_id,users.nameASusers_name,users.fullnameASusers_fullname,users.passwordASusers_passwordFROMusersORDERBYusers.id2.通過(guò)映射類的屬性字段查詢:#QueryingbyORM-instrumentforname,fullnameinsession.query(User.name,User.fullname):printname,full

3、name這種方法指定了查詢的具體字段,而不是像第一種方法那樣把映射類的所有字段都查詢出來(lái),其相當(dāng)于執(zhí)行了下面的SQL語(yǔ)句:SELECTusers.nameASusers_name,users.fullnameASusers_fullnameFROMusers3.query查詢的結(jié)果是保存在一個(gè)元組中的,所以我們可以在query中指定返回整個(gè)的映射類對(duì)象和其中的部分屬性字段:#QueryingasaPythonobjectforrowinsession.query(User,User.name).all():printr

4、ow.User,row.name這種查詢方法可以返回一個(gè)User對(duì)象以及它的name屬性字段的值,其相當(dāng)于執(zhí)行了下面的SQL語(yǔ)句:SELECTusers.idASusers_id,users.nameASusers_name,users.fullnameASusers_fullname,users.passwordASusers_passwordFROMusers其輸出結(jié)果為一個(gè)元組和一個(gè)字符串:<user("ed","EdJones","f8x902")>ed<user("Wendy","

5、WendyWilliams","foobar")>Wendy<user("Marry","MarryContrary","xxg527")>Marry<user("Fred","FredFlinstone","blah")>Fred4.我們還可以給返回的結(jié)果起一個(gè)別名,或者叫標(biāo)簽:#Queryinglabeledforrowinsession.query(User.name.label('name_label')).all():print(row.name_label)這里的關(guān)鍵是label

6、方法,它的意思是把User的name字段改個(gè)名字叫name_label,其相當(dāng)于執(zhí)行以下的SQL語(yǔ)句:SELECTusers.nameASname_labelFROMusers6.除了給映射類字段起別名,我們還可以給映射類起個(gè)別名:#Queryingwithaliasedfromsqlalchemy.ormimportaliaseduser_alias=aliased(User,name='user_alias')forrowinsession.query(user_alias,user_alias.name).all

7、():printrow.user_alias這里要注意的是,我們引入了aliased函數(shù),并且給User映射類起了個(gè)別名叫user_alias。然后我們就可以在query中使用這個(gè)別名了,它相當(dāng)于是User對(duì)象。上面的代碼相當(dāng)于執(zhí)行了以下SQL語(yǔ)句:SELECTuser_alias.idASuser_alias_id,user_alias.nameASuser_alias_name,user_alias.fullnameASuser_alias_fullname,user_alias.passwordASuser_al

8、ias_passwordFROMusersASuser_alias7.由于query的查詢返回的是一個(gè)元組,所以我們可以利用Python對(duì)數(shù)組類對(duì)象進(jìn)行“分片”的操作,來(lái)限制返回的結(jié)果集范圍:#Queryingwithlimitandoffsetforuinsession.query(User).order_by(User.id)

當(dāng)前文檔最多預(yù)覽五頁(yè),下載文檔查看全文

此文檔下載收益歸作者所有

當(dāng)前文檔最多預(yù)覽五頁(yè),下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學(xué)公式或PPT動(dòng)畫的文件,查看預(yù)覽時(shí)可能會(huì)顯示錯(cuò)亂或異常,文件下載后無(wú)此問(wèn)題,請(qǐng)放心下載。
2. 本文檔由用戶上傳,版權(quán)歸屬用戶,天天文庫(kù)負(fù)責(zé)整理代發(fā)布。如果您對(duì)本文檔版權(quán)有爭(zhēng)議請(qǐng)及時(shí)聯(lián)系客服。
3. 下載前請(qǐng)仔細(xì)閱讀文檔內(nèi)容,確認(rèn)文檔內(nèi)容符合您的需求后進(jìn)行下載,若出現(xiàn)內(nèi)容與標(biāo)題不符可向本站投訴處理。
4. 下載文檔時(shí)可能由于網(wǎng)絡(luò)波動(dòng)等原因無(wú)法下載或下載錯(cuò)誤,付費(fèi)完成后未能成功下載的用戶請(qǐng)聯(lián)系客服處理。