#数据类型转换
数据类型转换多发生在操作的输入类型与规定类型不一致,或一个表达式中包含多个不同数据类型的情况中,此时,可以通过隐式转换或显式转换来整合数据类型。
# 隐式转换(Implicit Data Conversion)
隐式转换表示在原始数据类型和目标数据类型不一致,且用户未指定类型转换函数时,YashanDB会运用一套转换规则来尝试转换数据类型,帮助用户降低SQL语句的编写难度,但如果超出了默认的转换范围,相应的SQL语句会报错。
以下场景中YashanDB默认进行隐式转换:
- INSERT/UPDATE语句中,要插入的数据将被转换成目标列的类型。
- 算术运算时,对参与运算的数据类型进行转换。
- 比较运算中,参与运算的数据类型不一致时,进行转换。
- 当向函数输入的参数为与定义不相符的数据类型时,该参数将先被隐式转换为可以接受的数据类型。
- PLSQL或接口程序中,Filter Condition使用绑定参数时,当输入的参数为与绑定列不相符的数据类型时,该参数将先被隐式转换为可以接受的数据类型。(绑定列为数值型时,输入参数将被执行向NUMBER类型的隐式转换)
执行隐式转换可能导致如下问题:
- FLOAT/DOUBLE类型本身是不精确的数据类型,执行与它们之间的类型可能会导致精度差异。
- 从TIMESTAMP转换为DATE,微秒会被舍弃。
下列表列示YashanDB支持的所有隐式转换:(列表示原始类型;行表示目标类型;✓表示支持转换,X表示不支持转换,--表示无需转换)
(1)
TINYINT | SMALLINT | INT | BIGINT | NUMBER | FLOAT | DOUBLE | 字符型 | |
---|---|---|---|---|---|---|---|---|
TINYINT | -- | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
SMALLINT | ✓ | -- | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
INT | ✓ | ✓ | -- | ✓ | ✓ | ✓ | ✓ | ✓ |
BIGINT | ✓ | ✓ | ✓ | -- | ✓ | ✓ | ✓ | ✓ |
NUMBER | ✓ | ✓ | ✓ | ✓ | -- | ✓ | ✓ | ✓ |
FLOAT | ✓ | ✓ | ✓ | ✓ | ✓ | -- | ✓ | ✓ |
DOUBLE | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | -- | ✓ |
字符型 | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | -- |
DATE | X | X | X | X | X | X | X | ✓ |
TIMESTAMP | X | X | X | X | X | X | X | ✓ |
YM_INTERVAL | X | X | X | X | X | X | X | ✓ |
DS_INTERVAL | X | X | X | X | X | X | X | ✓ |
TIME | X | X | X | X | X | X | X | ✓ |
BOOLEAN | ✓ | ✓ | ✓ | ✓ | ✓ | X | X | ✓* |
BIT | ✓ | ✓ | ✓ | ✓ | ✓ | X | X | ✓ |
CLOB | X | X | X | X | X | X | X | ✓ |
BLOB | X | X | X | X | X | X | X | ✓ |
NCLOB | X | X | X | X | X | X | X | ✓ |
RAW | X | X | X | X | X | X | X | ✓ |
JSON | X | X | X | X | X | X | X | ✓ |
ROWID | X | X | X | X | X | X | X | ✓ |
UROWID | X | X | X | X | X | X | X | ✓ |
*字符型中,仅支持特定字符串转为BOOL类型,详见布尔型。
(2)
DATE | TIMESTAMP | YM_INTERVAL | DS_INTERVAL | TIME | BOOLEAN | |
---|---|---|---|---|---|---|
TINYINT | X | X | X | X | X | ✓ |
SMALLINT | X | X | X | X | X | ✓ |
INT | X | X | X | X | X | ✓ |
BIGINT | X | X | X | X | X | ✓ |
NUMBER | X | X | X | X | X | ✓ |
FLOAT | X | X | X | X | X | X |
DOUBLE | X | X | X | X | X | X |
字符型 | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
DATE | -- | ✓ | X | X | X | X |
TIMESTAMP | ✓ | -- | X | X | X | X |
YM_INTERVAL | X | X | -- | X | X | X |
DS_INTERVAL | X | X | X | -- | ✓ | X |
TIME | X | X | X | ✓ | -- | X |
BOOLEAN | X | X | X | X | X | -- |
BIT | X | X | X | X | X | ✓ |
CLOB | X | X | X | X | X | X |
BLOB | X | X | X | X | X | X |
NCLOB | X | X | X | X | X | X |
RAW | X | X | X | X | X | X |
JSON | X | X | X | X | X | X |
ROWID | X | X | X | X | X | X |
UROWID | X | X | X | X | X | X |
(3)
BIT | CLOB | BLOB | NCLOB | RAW | JSON | ROWID | UROWID | |
---|---|---|---|---|---|---|---|---|
TINYINT | ✓ | ✓ | X | ✓ | X | X | X | X |
SMALLINT | ✓ | ✓ | X | ✓ | X | X | X | X |
INT | ✓ | ✓ | X | ✓ | X | X | X | X |
BIGINT | ✓ | ✓ | X | ✓ | X | X | X | X |
NUMBER | ✓ | ✓ | X | ✓ | X | X | X | X |
FLOAT | X | ✓ | X | ✓ | X | X | X | X |
DOUBLE | X | ✓ | X | ✓ | X | X | X | X |
字符型 | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
DATE | X | X | X | X | X | X | X | X |
TIMESTAMP | ✓ | X | X | X | X | X | X | X |
YM_INTERVAL | X | X | X | X | X | X | X | X |
DS_INTERVAL | X | X | X | X | X | X | X | X |
TIME | X | X | X | X | X | X | X | X |
BOOLEAN | ✓ | X | X | X | X | X | X | X |
BIT | -- | X | X | X | X | X | X | X |
CLOB | X | -- | X | X | X | ✓ | X | X |
BLOB | X | X | -- | X | ✓ | ✓ | X | ✓ |
NCLOB | X | ✓ | X | -- | X | ✓ | X | X |
RAW | X | ✓ | ✓ | X | -- | X | ✓ | ✓ |
JSON | X | ✓ | ✓ | ✓ | X | -- | X | X |
ROWID | X | X | X | X | ✓ | X | -- | ✓ |
UROWID | X | ✓ | ✓ | X | ✓ | X | ✓ | -- |
# 显式转换(Explicit Data Conversion)
显式转换是通过类型转换函数来清楚直言地指定转换的方向。相比隐式转换,显式转换可以使SQL语句更加容易理解,输出类型的可预测性更强。
下表举例列示YashanDB内置的一些类型转换函数:
函数 | 功能 |
---|---|
BIN | 其他类型向BIT类型转换。 |
NUMTODSINTERVAL | 数值型向INTERVAL DAY TO SECOND类型转换。 |
NUMTOYMINTERVAL | 数值型向INTERVAL YEAR TO MONTH类型转换。 |
SCN_TO_TIMESTAMP | BIGINT类型向TIMESTAMP类型转换。 |
TIMESTAMP_TO_SCN | TIMESTAMP类型向BIGINT类型转换。 |
TO_CHAR | 其他类型向VARCHAR类型转换。 |
TO_NUMBER | 其他类型向NUMBER类型转换。 |
TO_DATE | 其他类型向DATE类型转换。 |
TO_TIMESTAMP | 其他类型向TIMESTAMP类型转换。 |
TO_YMINTERVAL | 其他类型向INTERVAL YEAR TO MONTH类型转换。 |
TO_DSINTERVAL | 其他类型向INTERVAL DAY TO SECOND类型转换。 |
JSON | 字符串类型向JSON类型转换。 |
JSON_SERIALIZE | JSON类型向字符串类型转换。 |
CAST | 指定向任意类型转换。 |