要插入表中的數(shù)值也根據(jù)下面的步驟轉(zhuǎn)換成目標(biāo)列的數(shù)據(jù)類型。 值存儲數(shù)據(jù)類型解析 1. 查找與目標(biāo)準(zhǔn)確的匹配。 2. 否則,試著將表達(dá)式直接轉(zhuǎn)換成目標(biāo)類型。如果已知這兩種類型之間存在一個已注冊的轉(zhuǎn)換函數(shù), 那么直接調(diào)用該轉(zhuǎn)換函數(shù)即可。如果表達(dá)式是一個未知類型文本, 該文本字符串的內(nèi)容將交給目標(biāo)類型的輸入轉(zhuǎn)換過程。
例.character存儲類型轉(zhuǎn)換 對一個目標(biāo)列定義為character(20)的語句,下面的語句顯示存儲值的長度正確: CREATE TABLE vv (v character(20));INSERT INTO vv SELECT 'abc' || 'def';SELECT v, octet_length(v) FROM vv;v | octet_length----------------------+--------------abcdef | 20(1 row) 這里真正發(fā)生的事情是兩個 unknown 文本缺省解析成text, 這樣就允許||操作符解析成text連接。 然后操作符的text結(jié)果轉(zhuǎn)換成bpchar(“空白填充的字符型”, character類型內(nèi)部名稱)以匹配目標(biāo)列類型。(因為從text 到bpchar的轉(zhuǎn)換是二進(jìn)制兼容的,這樣的轉(zhuǎn)換是隱含的并且實際上不做任何函數(shù)調(diào)用。)最后,在系統(tǒng)表里找到長度轉(zhuǎn)換函數(shù)bpchar(bpchar, integer, boolean) 并且應(yīng)用于該操作符的結(jié)果和存儲的字段長。這個類型相關(guān)的函數(shù)執(zhí)行所需的長度檢查和額外的空白填充。 |
|