最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
解决C#在Oracle中使用参数执行失败问题
时间:2022-06-25 08:10:35 编辑:袖梨 来源:一聚教程网
其它的Oracle版本是否有这个问题不太清楚,至少是目前我测试的 Oracle 10g、Oracle 12c 都有这样的问题,执行后要么莫名其妙的报错、要么执行后返回0行受影响。
我的情况是这样的:使用C#调用了Oracle.ManagedDataAccess.dll 去访问数据库,执行Update语句 一点反应都没有。返回受影响行数为0。
排查
语句没错误、where条件也没错误。
不使用参数的方式执行完全没问题
最终检查了几个小时,网上居然找到了跟我遇到的一样情况的人。。。排查出来是Oracle中的语句与参数顺序一定要一致,感觉Oracle太不智能了。
案例如下
代码如下 | 复制代码 |
StringBuilder strSql = new StringBuilder(); |
最关键的就在于SQL语句与OracleParameter参数的顺序,顺序一定要一致!所以需要这样写:
代码如下 | 复制代码 |
OracleParameter[] parameters = { new OracleParameter(":Mac_Address", OracleDbType.Varchar2,17), new OracleParameter(":Mac_Status", OracleDbType.Int32,4), new OracleParameter(":MacInfo_ID", OracleDbType.Varchar2,17)}; |
自然,赋值就不用说了,跟着parameters走。
这样就OK了。
相关文章
- 鸣潮2.7版本复刻角色都有谁 鸣潮2.7版本上下半卡池复刻角色一览 10-14
- 灵画师兑换码2025最新可用兑换码 灵画师兑换码大全汇总 10-14
- 盛世天下官方网站在哪 盛世天下官网首页入口 10-14
- 羊蹄山之魂是独占吗 羊蹄山之魂独占时间介绍 10-14
- 三角洲行动密码门大全(每日更新) 全地图今日密码更新汇总 10-14
- 羊蹄山之魂pc什么时候上 羊蹄山之魂pc版预计上线时间 10-14