oracle小数点前零丢失的问题

1.问题起源  
      oracle  数据库 字段值为小于1的小数时,使用char类型处理,会丢失小数点前面的0  
      例如0.2就变成了.2 
2.解决办法:

(1)用to_char函数格式化数字显示  
      select     to_char(0.338,‘fm9999999990.00‘) from dual;  
     结果:0.34  
     这里重点要看 fm9999999999.99,表示整数部分最多10位,小数部分2位,fm表示去 掉转位字符串后前面的空格,不加fm,0.34前面会有空格的.

(2)使用decode函数

既然小于1的小数首位必然是‘.‘,那就判断首位是否为‘.‘,是则在前面加上‘0‘即可

SQL> select decode(substr(num,1,1),‘.‘,‘0‘||num,num) from t1_number

DECODE(SUBSTR(NUM,1,1),‘.‘,‘0‘||NUM,NUM)

时间: 2024-10-23 15:36:57

oracle小数点前零丢失的问题的相关文章

小数点前零丢失

select TO_CHAR(0.3678,'FM9999.99')||'%' AS A, TO_CHAR(0.3678,'FM9990.9')||'%' AS B, TO_CHAR(0.3678,'9990.0')||'%' AS C, TO_CHAR(0.3678,'FM9990.09')||'%' AS D, TO_CHAR(0.3678,'FM9990.009')||'%' AS E, TO_CHAR(0.3678,'FM000.00000')||'%' AS F from dual;

oracle查询不显示小数点前的0

1.问题起源       oracle 数据库字段值为小于1的小数时,使用char类型处理,会丢失小数点前面的0       例如0.35就变成了.35 2.解决办法:用to_char函数格式化数字显示       select     to_char(0.338,'fm9999999990.00') from dual;      结果:0.34      这里重点要看 fm9999999999.99,表示整数部分最多10位,小数部分2位,fm表示去 掉转位字符串后前面的空格,不加fm,0.3

Oracle中绝对值小于1的小数如何显示小数点前面的0

在oracle 中 如果是绝对值小于1的小数,则只会显示小数点后面的值,小数点前面的0就会被忽略掉,例如: 0.1  在oracle中会被显示为 .1 如何解决此类问题: x=0.2 TO_CHAR('fm9999990.9999',x) 输出值为 0.2 但是现在出现了一个问题,如果是x=10,那么跟显示就会为10. ,在后面会多一个小数点,这样很不好看,怎么才能显示实际的输入,在网上找了ORACLE 的另外一个字符处理函数rtrim,所以现在这些按照如下的更改即可: x =10 RTRIM(

Spark Streaming使用Kafka保证数据零丢失

来自: https://community.qingcloud.com/topic/344/spark-streaming使用kafka保证数据零丢失 spark streaming从1.2开始提供了数据的零丢失,想享受这个特性,需要满足如下条件: 数据输入需要可靠的sources和可靠的receivers 应用metadata必须通过应用driver checkpoint WAL(write ahead log) 可靠的sources和receivers spark streaming可以通过

SQL Server 字段类型 decimal(18,6)小数点前是几位?记一次数据库SP的BUG处理

原文:SQL Server 字段类型 decimal(18,6)小数点前是几位?记一次数据库SP的BUG处理 SQL Server 字段类型 decimal(18,6)小数点前是几位? 不可否认,这是一个很低级的问题.... 为什么会问这么低级的问题? 由于这个问题,导致一个数据导入的SP执行失败....以至于困扰了我好几个小时.... 事情是这样的... 公司总部上了一套Oracle的ERP,我们系统中有些数据要从里面取,比如Supplier,Product等. Oracle会导出数据文件,我

iOS textField输入金额的限制,小数点前9位,后面两位

iOS textField输入金额的限制,小数点前9位,后面两位,如果不加小数点,最大位数是9位,加上小数点,最大位数是12位,超出最大位数可删除 - (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string { // 判断是否输入内容,或者用户点击的是键盘的删除按钮 if (![string isEqualT

Oracle查询前10条记录及分页查询(第5条到第10记录)

如果你想了解Oracle查询前10条记录的相关实际应用方案的话,你就可以点击以下的文章对其在实际相关操作中的正确用法,有一个更加完善的认识,希望你在浏览完以下的文章会以下就是正文的详细内容的介绍. 在Oracle怎样查询表中的top10条记录呢? select *   from test   where rownum <=10   下面是关于rownum的介绍 Rownum和row_number() over()的使用 ROWNUM是Oracle从8开始提供的一个伪列,是把SQL出来的结果进行编

页面显示数据,小数点前的零不见了

遇到问题时的页面显示以及数据库中查出的数据: 原因:数字格式化没弄好 解决方法: 解决好后的页面显示:

Oracle升级前备份和失败回退

一.升级前备份 1.软件备份[[email protected] backup]# su - oracle [[email protected] ~]$ cd $ORACLE_HOME[[email protected] db_1]$ pwd/db/oracle/oracle/product/10.2.0/db_1[[email protected] db_1]$ tar -cvzf ora_home.tar.gz ./软件升级主要是对ORACLE_HOME下的文件进行修改,先对其打tar包.