第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

cx_Oracle:如何迭代結(jié)果集?

cx_Oracle:如何迭代結(jié)果集?

有幾種方法可以迭代結(jié)果集。兩者的權(quán)衡是什么?
查看完整描述

3 回答

?
忽然笑

TA貢獻(xiàn)1806條經(jīng)驗(yàn) 獲得超5個(gè)贊

規(guī)范的方法是使用內(nèi)置的游標(biāo)迭代器。

curs.execute('select * from people')for row in curs:    print row

您可以使用fetchall()一次獲取所有行。

for row in curs.fetchall():
    print row

使用此命令創(chuàng)建包含返回值的Python列表可能會(huì)很方便:

curs.execute('select first_name from people')names = [row[0] for row in curs.fetchall()]

這對(duì)于較小的結(jié)果集可能很有用,但是如果結(jié)果集很大,可能會(huì)產(chǎn)生不良的副作用。

  • 您必須等待整個(gè)結(jié)果集返回給客戶流程。

  • 您可能會(huì)吞噬客戶端中的大量?jī)?nèi)存來(lái)保存內(nèi)置列表。

  • Python可能需要一些時(shí)間來(lái)構(gòu)造和解構(gòu)您將立即丟棄的列表。


如果您知道結(jié)果集中僅返回一行,則可以調(diào)用fetchone()以獲取該行。

curs.execute('select max(x) from t')maxValue = curs.fetchone()[0]

最后,您可以遍歷結(jié)果集,一次獲取一行。通常,與使用迭代器相比,這樣做沒(méi)有什么特別的優(yōu)勢(shì)。

row = curs.fetchone()while row:
    print row
    row = curs.fetchone()


查看完整回答
反對(duì) 回復(fù) 2021-03-22
?
largeQ

TA貢獻(xiàn)2039條經(jīng)驗(yàn) 獲得超8個(gè)贊

我的首選方式是游標(biāo)迭代器,但首先要設(shè)置游標(biāo)的arraysize屬性。

curs.execute('select * from people')curs.arraysize = 256for row in curs:    print row

在此示例中,cx_Oracle將一次從Oracle 256行中獲取行,從而減少了需要執(zhí)行的網(wǎng)絡(luò)往返次數(shù)


查看完整回答
反對(duì) 回復(fù) 2021-03-22
  • 3 回答
  • 0 關(guān)注
  • 385 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)