OCI-22053: 溢出错误(附解决办法)

      长话短说,一句话,Oracle 最多可存储可存储 38 个字节的精度。当将 Oracle 数值转换为公共语言运行库数据类型时,小数点后边的位数过多,就可能会出现此错误。

      检查你的sql语句中是不是没对小数位数做限制。或者出现了无限循环or无限不循环小数。

解决方案:使用round(value,2) 使小数位数按照四舍五入保留后2位。

      以下为反思。

      项目中有一个提交的按钮,点击的时候会把前台页面的各项信息值传到后台,后台进行判重、校验等插入或更新操作。突然今天晚上,夺命连环call说该按钮点击了报错,并且页面也没有到提交后的页面。

      乍一看,觉得很奇怪。因为就是个接口。后台接口是这样的:

      中规中矩,业务逻辑代码封装起来,try{}catch{}模块也正常。此时仍然不能快速定位原因。于是目光转到前台,想看看接口返回的什么给了前台。令人诧异的是,前台居然收到了一个空的值。此时已经不能快速定位问题了,必须要看封装的代码了。

      打上调式,发起请求。一步步调试中,突然有个断点直接过去了。发现如下代码

DataTable dt = GetData(id);

if (dt .Rows.Count > 0)
{
    //业务代码
}
return uid;


public DataTable GetData(string id)
{
    DataTable dt = new DataTable();
    try{
        ///出问题的SQL ,使用结束时间减去开始时间 selectet
    }
    catch(Exception ex){}
    return dt;
}

      至此,前台收到的值为什么空了真相了。封装代码时,异常没有统一处理,导致捕获了异常,但是处理掉了,造成前台收到了非常规的回应。

       但是新的问题又来了,在Oracle 中,两个时间直接相减,为什么是一串无限循环小数呢?默认显示是天数啊,进一步观察项目中开始日期和结束日期的值,很无奈的发现

       结束时间为20xx-0x-xx 23:59:59,开始时间为20xx-0x-xx 00:00:00。

        业务逻辑是算天,这里精确到了时分秒,不用想,又是哪个天才,结束时间选在了23:59:59这个时间端,除了这非常规的操作,代码层面也没考虑周全,才导致了这个奇怪的BUG产生。  

      如果设计时,明确业务逻辑是算天,加以校验,或者编写代码时,多考虑下需求,也许就没今天的Bug了。

奇怪的现象,有时候往往只是一个低级的错误,但这个低价的错误加上其他因素,就变得令人费解。所以一定要静下心来,抽丝剥茧,找出问题的根源。

     

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: OCI runtime创建失败是由于提供了但没有定义标志“-console-socket: u”。这个错误通常是因为在创建容器运行时使用了未定义或不支持的标志。 容器运行时是一个用于管理和运行容器的软件。在创建容器时,可以通过命令行选项或配置文件来指定不同的参数和标志。每个容器运行时都具有特定的标志和选项,用于配置容器的行为。 在这种情况下,错误指出使用了一个名为“-console-socket: u”的标志,但该标志并未被容器运行时定义或支持。可能原因是版本不兼容,或者使用了错误的标志名称。 解决这个问题的方法是查阅所使用的容器运行时的文档,确保使用正确的标志和选项。如果是版本不兼容引起的问题,需要更新容器运行时到与提供的标志相兼容的版本。另外,还可以尝试使用其他选项代替“-console-socket: u”,以满足容器的运行需求。 综上所述,OCI runtime创建失败是由于提供了未定义或不支持的标志“-console-socket: u”。需要检查使用的容器运行时的文档,并确保使用正确的标志和选项来解决这个问题。 ### 回答2: 这个错误是由于OCI运行时创建失败,并提示指定的标志未定义:-console-socket: u。 OCI是Open Container Initiative的缩写,是一个开放的行业标准,用于容器运行时和容器格式。OCI运行时是负责创建和管理容器的程序。 在这个错误中,-console-socket: u是一个无效的命令行选项。这意味着你输入了一个OCI运行时无法识别的选项。 要解决这个问题,你需要检查你输入的OCI运行时命令,并确保所有的选项都是有效的。可能是你误输入了一个错误的选项,导致OCI运行时无法正确解析命令。 另外,你也可以查看OCI运行时的文档或官方文档,以了解所有支持的命令和选项。这样可以确保你正确使用OCI运行时,并避免类似的错误。 总之,-console-socket: u是一个无效的命令行选项,导致OCI运行时创建失败的错误。检查你输入的OCI运行时命令,并确保所有的选项都是有效的,可以帮助你解决这个问题。 ### 回答3: 这个错误提示是由于在创建OCI容器的过程中使用了一个未定义的标志“-console-socket: u”。 OCI(Open Container Initiative)是一个为容器提供标准规范的项目,它定义了容器的运行时和镜像格式。在创建OCI容器时,我们可以使用各种选项和标志来配置容器的环境和行为。 然而,根据错误提示,这个标志“-console-socket: u”是未定义的,所以容器运行时无法识别它。这可能是因为你在使用容器运行时的命令中错误地输入了该标志,或者容器运行时版本不支持该标志。 要解决这个问题,你可以尝试以下几个步骤: 1. 检查命令行中是否正确拼写了所有标志和选项,确保没有错误输入。 2. 确认你使用的容器运行时版本是否支持这个标志。你可以查看相关文档或官方网站来获取容器运行时的最新信息。 3. 如果你确实需要使用该标志,但当前容器运行时版本不支持,可以尝试升级容器运行时或切换到其他支持该标志的运行时。 另外,你也可以尝试搜索相关错误信息,查看是否有其他人遇到了相同的问题,并找到解决方案。在互联网上的开发者社区和论坛上寻求帮助也是一个不错的选择。 总之,这个错误提示意味着你在创建OCI容器时使用了一个未定义的标志“-console-socket: u”,你需要检查命令行的输入、容器运行时版本以及寻找相关解决方案来解决这个问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值