Sql 如何在解码表达式后查找列类型
如何在解码表达式后显示类型。一、 下面是一个查询,我需要知道表达式解码的列类型 当前查询:Sql 如何在解码表达式后查找列类型,sql,oracle,Sql,Oracle,如何在解码表达式后显示类型。一、 下面是一个查询,我需要知道表达式解码的列类型 当前查询: select decode(column1,column2,2,'3') result from tablename 所需查询: select decode(column1,column2,2,'3') result,calculationoftype.... columntype from tablename 我想你有些困惑decode()是一个表达式,它只返回一种类型。在您的情况下,该类型是nu
select decode(column1,column2,2,'3') result from tablename
所需查询:
select decode(column1,column2,2,'3') result,calculationoftype.... columntype from tablename
我想你有些困惑
decode()
是一个表达式,它只返回一种类型。在您的情况下,该类型是number
正如秘书长解释的那样:
Oracle会自动将返回值转换为与相同的数据类型
第一个结果。如果第一个结果的数据类型为CHAR,或者
第一个结果为null,然后Oracle将返回值转换为
数据类型VARCHAR2
在您的例子中,第一个结果是一个数字,因此返回类型是一个数字。我认为您对某些事情感到困惑
decode()
是一个表达式,它只返回一种类型。在您的情况下,该类型是number
正如秘书长解释的那样:
Oracle会自动将返回值转换为与相同的数据类型
第一个结果。如果第一个结果的数据类型为CHAR,或者
第一个结果为null,然后Oracle将返回值转换为
数据类型VARCHAR2
在您的例子中,第一个结果是一个数字,因此返回类型是一个数字。将
'3'
更改为'Z'
,看看当列1
列2
时会发生什么……将'3'
更改为'Z'
并查看列1
列2
时会发生什么……但这样的查询是有效的,我很感兴趣的是结果的类型新专栏抱歉我理解你的意思以及我如何看到专栏的类型?是否有函数?@seyxsultan-您可以使用查看列或表达式的实际数据类型。还提供了数据类型代码。不管怎么说,大多数普通的。@AlexPoole谢谢你!但是像这样的查询是有效的,我很感兴趣的是新列的结果类型对不起,我理解你的意思,以及我如何看到列的类型?是否有函数?@seyxsultan-您可以使用查看列或表达式的实际数据类型。还提供了数据类型代码。不管怎么说,大多数普通的。@AlexPoole谢谢你!