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

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

PostgreSQL,允許按不存在的字段進(jìn)行過濾

PostgreSQL,允許按不存在的字段進(jìn)行過濾

Go
慕少森 2022-08-15 15:34:48
我正在使用帶有Go驅(qū)動(dòng)程序的PostgreSQL。有時(shí)我需要查詢不存在的字段,只是為了檢查 - 也許數(shù)據(jù)庫(kù)中存在某些內(nèi)容。在查詢之前,我無(wú)法判斷該字段是否存在。例:where size=10 or length=10默認(rèn)情況下,我收到一個(gè)錯(cuò)誤,但是,該列可能存在,我可以得到一些結(jié)果。column "length" does not existsize是否有可能處理此類情況以返回可能的內(nèi)容?編輯:是的,我可以先獲取所有現(xiàn)有列。但是初始查詢可能相當(dāng)復(fù)雜,不是由我直接創(chuàng)建的,我只能修改它們。這意味著查詢可以像前面的示例一樣簡(jiǎn)單,也可以像下面這樣復(fù)雜得多:WHERE size=10 OR (length=10 AND n='example') OR (c BETWEEN 1 and 5 AND p='Mars')如果缺少列和 - 這是否意味著我必須解析SQL,按(或其他運(yùn)算符)拆分它,檢查查詢的每個(gè)部分,然后刪除任何缺少列的部分 - 最后生成新的SQL查詢?lengthcOR任何更簡(jiǎn)單的方法?
查看完整描述

3 回答

?
守著星空守著你

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

除了從可用列列表中構(gòu)造SQL字符串之外,沒有辦法做你想做的事情,可以通過查詢來(lái)獲取。information_schema.columns

SQL 語(yǔ)句在執(zhí)行之前進(jìn)行分析,并且沒有條件編譯或短路,因此如果引用了不存在的列,則會(huì)出現(xiàn)錯(cuò)誤。


查看完整回答
反對(duì) 回復(fù) 2022-08-15
?
holdtom

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

為什么不先獲得表中列的列表?喜歡這個(gè)


select column_name 

from information_schema.columns 

where table_name = 'table_name' and (column_name = 'size' or column_name = 'length');

結(jié)果將是存在的列。


查看完整回答
反對(duì) 回復(fù) 2022-08-15
?
汪汪一只貓

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

我會(huì)嘗試首先檢查信息架構(gòu)

“從INFORMATION_SCHEMA中選擇column_name。table_name ='table_name';”

然后根據(jù)結(jié)果做查詢


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

添加回答

舉報(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)