日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

OushuDB 用戶指南之類型轉(zhuǎn)換值存儲

 北漂二號 2021-12-22

要插入表中的數(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)換過程。

  1. 檢查一下看看目標(biāo)類型是否有長度轉(zhuǎn)換。長度轉(zhuǎn)換是一個從某類型到自身的轉(zhuǎn)換。如果在pg_cast表里面找到一個,那么在存儲到目標(biāo)列之前先在表達(dá)式上應(yīng)用。 這樣的轉(zhuǎn)換函數(shù)總是接受一個額外的類型為integer的參數(shù), 它接收目標(biāo)字段的atttypmod值(實際上是其聲明長度,atttypmod 的解釋隨不同的數(shù)據(jù)類型而不同),并且它可能接受一個boolean類型的第三個參數(shù), 表示轉(zhuǎn)換是顯式的還是隱式的。轉(zhuǎn)換函數(shù)負(fù)責(zé)施加那些長度相關(guā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í)行所需的長度檢查和額外的空白填充。

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多