資源描述:
《python訪問數(shù)據(jù)庫, sqlalchemy中的query方法》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在行業(yè)資料-天天文庫。
1、SQLAlchemy中的Query方法在SQLAlchemy中執(zhí)行查詢是通過session對(duì)象的query方法完成的。query方法非常靈活,你可以根據(jù)需要使用不同的查詢方式查找數(shù)據(jù),下面一一舉例。1.直接通過映射類查找:#Queryinguserinstanceforinstanceinsession.query(User).order_by(User.id):printinstance.name,instance.fullname這種方法只要在query方法中,將映射類作為參數(shù),就可以查詢出這個(gè)映射類代表的數(shù)據(jù)庫表中的數(shù)據(jù)。其相當(dāng)于下面的SQL語句:SELECTuser
2、s.idASusers_id,users.nameASusers_name,users.fullnameASusers_fullname,users.passwordASusers_passwordFROMusersORDERBYusers.id2.通過映射類的屬性字段查詢:#QueryingbyORM-instrumentforname,fullnameinsession.query(User.name,User.fullname):printname,fullname這種方法指定了查詢的具體字段,而不是像第一種方法那樣把映射類的所有字段都查詢出來,其相當(dāng)于執(zhí)行了下面的S
3、QL語句:SELECTusers.nameASusers_name,users.fullnameASusers_fullnameFROMusers3.query查詢的結(jié)果是保存在一個(gè)元組中的,所以我們可以在query中指定返回整個(gè)的映射類對(duì)象和其中的部分屬性字段:#QueryingasaPythonobjectforrowinsession.query(User,User.name).all():printrow.User,row.name這種查詢方法可以返回一個(gè)User對(duì)象以及它的name屬性字段的值,其相當(dāng)于執(zhí)行了下面的SQL語句:SELECTusers.idASuse
4、rs_id,users.nameASusers_name,users.fullnameASusers_fullname,users.passwordASusers_passwordFROMusers其輸出結(jié)果為一個(gè)元組和一個(gè)字符串:<user("ed","EdJones","f8x902")>ed<user("Wendy","WendyWilliams","foobar")>Wendy<user("Marry","MarryContrary","xxg527")>Marry<user("Fred","FredFlins
5、tone","blah")>Fred4.我們還可以給返回的結(jié)果起一個(gè)別名,或者叫標(biāo)簽:#Queryinglabeledforrowinsession.query(User.name.label('name_label')).all():print(row.name_label)這里的關(guān)鍵是label方法,它的意思是把User的name字段改個(gè)名字叫name_label,其相當(dāng)于執(zhí)行以下的SQL語句:SELECTusers.nameASname_labelFROMusers6.除了給映射類字段起別名,我們還可以給映射類起個(gè)別名:#Queryingwithaliasedfrom
6、sqlalchemy.ormimportaliaseduser_alias=aliased(User,name='user_alias')forrowinsession.query(user_alias,user_alias.name).all():printrow.user_alias這里要注意的是,我們引入了aliased函數(shù),并且給User映射類起了個(gè)別名叫user_alias。然后我們就可以在query中使用這個(gè)別名了,它相當(dāng)于是User對(duì)象。上面的代碼相當(dāng)于執(zhí)行了以下SQL語句:SELECTuser_alias.idASuser_alias_id,user_ali
7、as.nameASuser_alias_name,user_alias.fullnameASuser_alias_fullname,user_alias.passwordASuser_alias_passwordFROMusersASuser_alias7.由于query的查詢返回的是一個(gè)元組,所以我們可以利用Python對(duì)數(shù)組類對(duì)象進(jìn)行“分片”的操作,來限制返回的結(jié)果集范圍:#Queryingwithlimitandoffsetforuinsession.query(User).order_by(User.id)