oracle中怎么将int类型转换string类型

如题所述

将int类型转换string类型方法如下:

select CAST(A.xxx AS CHAR) as xxx,A.zzz  from A wher A.yyy = '123' ;

Oracle的三大类型转换:

1、使用to_char(日期,‘格“常量”式')函数将日期转成字符串

例1:显示如下格式:2018年05月10日 星期四

selelct to_char(sysdate,'yyyy"年"mm"月"dd"日"day');

例2:显示格式:2015-04-25 今天是星期六 15:15:15

select to_char(sysdate,'yyyy-mm-dd"今天是"day hh24:mi:ss');

2、使用to_char(数值,格式)函数将数值转成字符串。

例1:显示格式:$1,234

select to_char(1234,'$9,999') from clual;

例2:显示格式:¥1,234

select to_char(1234,'L9,999') from clual;

3、使用to_char('字符串','格式')函数,将字符串转成date类型:

例:chax 1980年12月17日入职的员工

select * from emp

where hiredate=todate('1980年12月17日','yyyy"年"mm"月"dd"日"');

4、使用to_number('字符串')函数将字符串转成数字。

扩展资料

Oracle函数的工作方式有两种:

1、根据旧的对象创建新的对象——他们对原来的信息进行修改,如改变字母的大小写。

2、告诉用户有关的信息,如一个单词或句子中有几个字符。

Oracle中主要有两种字符串类型:CHAR和VARCHAR2,他们以字母,标点,数字和空格的混合形式存在。

CHAR串始终为定长的,如果设置的值长度小于CHAR列的串值,会自动填充空格。在比较CHAR串时,会为双方都补满空格后再进行比较。

VARCHAR2数据类型为边长的串(VARCHAR与VARCHAR2为同义词)。

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-09-06
可以使用to_char函数进行数据类型转换。
to_char函数可以把各种数据类型转换成格式化的字符串。
其中:
to_char(timestamp, text) 把 timestamp 转换成 string
to_char(date, text)把date转换成string
to_char(int, text)把Int转换成string
to_char(float, text)把float转换成string
to_char(numeric, text)把numeric转换成string
第2个回答  推荐于2017-09-07

1、oracle内部会自动转换的,比如数字型会自动后转为字符型

2、oracle 里没有int和string类型

3、你应该是在其他语言的程序中要将数值型的转换为字符型的吧,此时有两种方法:

    在sql语句中写转换函数to_char(xx),或者让该字段||‘’;

    在你的程序中直接转换

--希望对你有帮助!

追问

帮助是有,但是还是报错

追答

什么错呢?具体点。
你是要在数据库你面转换,还是在其他语言中转?
有图有代码--有真相!!!

追问

追答

你确定lettercount这个自字段存在!? 你的截图上说的是列不属于。。。table。
Arch_ArchivesM 这张比表有这个字段吗?

追问

我不加后台蓝线代码就没事。

本回答被提问者采纳
第3个回答  2014-06-30
to_char(15) 结果就是 '15'追问

select ShareCount,to_number(LetterCount),DrawingCount,,to_char(ArchivesEditDate, 'yyyy-mm-dd') where apanagecode='4753' order by archivesno
LetterCount用to_char不行

追答

你写错了,to_char, 你写了to_number...

第4个回答  2014-06-30
select id||'' from a;追问

只能改sql语句, 把字段int类型改成string类型,貌似行不通。

追答

得到想要的结果就可以了

追问

select LetterCount from Set
LetterCount是int,你改 我看 ,我要实现的是 LetterCount 现实1-2

追答

select LetterCount||‘’ from Set

追问

这个查询的 蓝线那个 怎么错了

相似回答