python一次性封裝多條sql語(yǔ)句的實(shí)現(xiàn)方法-創(chuàng)新互聯(lián)

這篇文章主要講解了python一次性封裝多條sql語(yǔ)句的實(shí)現(xiàn)方法,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。

專(zhuān)注于為中小企業(yè)提供成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)湯陰免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了超過(guò)千家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

python封裝利用begin end執(zhí)行多條sql

因?yàn)闃I(yè)務(wù)需求,優(yōu)化模型運(yùn)行時(shí)間。考慮到sql語(yǔ)句每一次執(zhí)行都要建立連接,查詢,獲取數(shù)據(jù)耗時(shí)過(guò)多。就想到將sql一起提交上去運(yùn)行,能夠節(jié)省很多時(shí)間。原本1.6-2.5秒耗時(shí)的sql語(yǔ)句經(jīng)過(guò)修改后時(shí)間降到0.3-0.6秒,感覺(jué)性能提升挺好的。

當(dāng)然還有一種想法,如果有python框架的orm可能會(huì)更快,相比來(lái)說(shuō)耗時(shí)基本看不到了吧,這只是我的猜想,僅僅為了優(yōu)化一個(gè)模型寫(xiě)一個(gè)框架的話 代碼可能需要改的比較多,自我感覺(jué)付出和收獲不一定會(huì)成正比,當(dāng)然以后有時(shí)間可以試試。

這次優(yōu)化基本代碼邏輯沒(méi)有動(dòng),利用了begin end進(jìn)行sql整合。

公司用的是oracle,之前沒(méi)用過(guò)但是感覺(jué)和mysql基本類(lèi)似,如果是mysql的話該方法也可用

sql_str = ‘begin\n'
sql_str += ‘這里時(shí)需要執(zhí)行的sql語(yǔ)句'
sql_str += ‘\ncommit;end;'

中間sql有多少條無(wú)所謂,看了一下運(yùn)行時(shí)間感覺(jué) 我的一千行sql耗時(shí) 幾乎就是這一千行里面耗時(shí)最長(zhǎng)那個(gè)時(shí)間。是異步完成還是什么這個(gè)就不是很清楚了,主要是一次建立連接,省去網(wǎng)絡(luò)傳輸數(shù)據(jù)和請(qǐng)求數(shù)據(jù)庫(kù)的過(guò)程

網(wǎng)上好多begin end都是在可視化工具中的sql執(zhí)行的,并不能在command中執(zhí)行,這就意味中我們代碼中封裝的語(yǔ)句沒(méi)有卵用,還好沒(méi)放棄當(dāng)時(shí)就研究了一下找到了解決辦法

在end 提交一下就ok了,如果在command中運(yùn)行一直未結(jié)束的話加一個(gè) / 斜線就ok了

本次內(nèi)容就此結(jié)束,下面是一些題外話。

在說(shuō)一個(gè)其中遇到的問(wèn)題吧,在進(jìn)行sql封裝后,其中很多表都很亂,約束很亂 而且邏輯并不嚴(yán)謹(jǐn),但是模型正在運(yùn)行還不讓動(dòng) 那只能按照這個(gè)規(guī)則來(lái)了

ORA 00001 違反唯一約束條件 其中出現(xiàn)了這個(gè)問(wèn)題,意思就是唯一約束重復(fù)了,因?yàn)槟P洼斎雴?wèn)題,處理出來(lái)的結(jié)果之前可能剛插入到數(shù)據(jù)庫(kù)中(也就是 上面的sql_str 出現(xiàn)了兩天相同的insert),這個(gè)東西很簡(jiǎn)單,加一個(gè)set判斷一下就行,但是到這之后,一個(gè)bug就跳出來(lái)了,這個(gè)腳本計(jì)算的是因子重要度,結(jié)果預(yù)測(cè)可能每次都不相同,有些數(shù)據(jù)很小的可能就當(dāng)成0扔進(jìn)去了,所以我需要做的是將 相同數(shù)據(jù)的情況下插入較為重要的因子重要度(也無(wú)需要 ),這樣的話簡(jiǎn)簡(jiǎn)單單的set就不行了,但是也不難 用來(lái)一下字典

 importance_map = {}
 實(shí)現(xiàn)創(chuàng)建好字典
 if feature in importance_map:
        if importance_map[feature] < importance:
          sql_str +=‘***************‘'' 這里就是insert語(yǔ)句了
        else:
          continue
      else:
        importance_map[feature] = importance

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

網(wǎng)頁(yè)題目:python一次性封裝多條sql語(yǔ)句的實(shí)現(xiàn)方法-創(chuàng)新互聯(lián)
文章出自:http://www.muchs.cn/article30/spppo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、App設(shè)計(jì)、搜索引擎優(yōu)化網(wǎng)站導(dǎo)航、手機(jī)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作