使用指示符变量向ORACLE表中插入空值的问题

li602714 2009-04-02 12:04:59
各位大大:
我使用OCI接口访问ORACLE,在向表中插入记录时要根据变量值确定是否插入空值,因此我使用了指示符变量,代码如下:
bool COracle::InsertIntoTable(char* pcName, int& iAge)
{
//SQL语句
char chrSqlStr[512] = "INSERT INTO T_TABLE (NAME,AGE) VALUES (:1,:2)";
sb2 Flag;
//定义绑定句柄
OCIBind* bindhp_Prompt;
OCIBind* bindhp_Remark;

OCIStmtPrepare(mystmthp, myerrhp, (text *)chrSqlStr, strlen(chrSqlStr), OCI_NTV_SYNTAX, OCI_DEFAULT)) )

//位置绑定
if ( strlen(pcName) >= 0 ) Flag=-1; else Flag=0;
OCIBindByPos(mystmthp, &bindhp_Prompt, myerrhp, 1, (dvoid *)pcName, 15, SQLT_STR, (dvoid*)&Flag, 0, 0, 0, 0, OCI_DEFAULT);

if ( iAge <= 0 ) Flag=-1; else Flag=0;
OCIBindByPos(mystmthp, &bindhp_Remark, myerrhp, 2, (dvoid *)&iAge, sizeof(int), SQLT_INT, (dvoid*)&Flag, 0, 0, 0, 0, OCI_DEFAULT);

//执行
OCIStmtExecute(mysvchp, mystmthp, myerrhp, 1, 0, NULL, NULL, OCI_COMMIT_ON_SUCCESS);
return true;
}

我是原意是当iAge的值小于1时,AGE字段就插入空值,这段代码在大部份时候不能正确插入空值,但偶尔也可以插入空值,不明白是为什么?
请教各位大大,谢谢

另外请问,我的程序里要提供ACCESS, SQLSERVER,ORACLE三种数据库的接口,是使用一种访问方式好,还是各用各的访问方式好,像ORACLE我就一直用的OCI,但其它的显然不能用OCI,怎么样更好一点?
...全文
751 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
li602714 2009-04-13
  • 打赏
  • 举报
回复
知道的同志来看看啊
li602714 2009-04-07
  • 打赏
  • 举报
回复
在OCI中,SQL语句中的占位符变量用于指示数据必须存储的实际位置,占位符变量通过冒号来表示,如:1
使用占位符可以动态插入多条记录,提高SQL语句的使用效率。如向学生信息表中插入多个学生的资料。
对于每个占位符,可以调用OCI函数来绑定其对应的变量地址。在执行SQL语句时,ORACLE会将得到的输入数据、绑定数据或变量值传给服务器端,与服务器端实时交互。
绑定占位符主要有以下几种方式
1、OCIBindByName()
2、OCIBindByPos()
3、OCIBindObject()
4、OCIBindDynamic()
5、OCIBindArrayOfStruct()
jdsnhan 2009-04-06
  • 打赏
  • 举报
回复
我提供的方法仅从oracle角度讲
oci不熟悉。
cheng_fengming 2009-04-06
  • 打赏
  • 举报
回复
oracle里面插入语句不是这样的么
INSERT INTO T_TABLE (NAME,AGE) VALUES ('1',2);
这样传值可以吗?
INSERT INTO T_TABLE (NAME,AGE) VALUES (:1,:2);
li602714 2009-04-03
  • 打赏
  • 举报
回复
用1楼的方法试了一下,
"INSERT INTO T_TABLE (NAME,AGE) VALUES (:1,case when :2 <1 then null else :2 end)";
发现OCIStmtExecute时会出错,调用OCIErrorGet得到信息是"ORA-01008:并非所有变量都已绑定",但我是绑定了的,指示符变量的位置写的是"0"
是我什么地方没注意到吗?在end后面加逗号也不行

后来偶然试到用如下绑定语句可以实现
OCIBindByPos(mystmthp, &bindhp_Remark, myerrhp, 2, (dvoid *)&iAge, sizeof(int), SQLT_INT, &Flag, 0, 0, 0, 0, OCI_DEFAULT);
少了对批示符变量地址的强制转换(dvoid*),可我不确定这是不是偶尔能实现,因为我最初按照参考的方法在调的时候也是
能实现的,但上了系统后就出问题了
用同样的方法作输出变量是否空值的判断也得不到正确结果,看来ORACLE参考上的说法我还没弄清楚
jdsnhan 2009-04-02
  • 打赏
  • 举报
回复
1、建议方法,在语句中处理
char chrSqlStr[512] = "INSERT INTO T_TABLE (NAME,AGE) VALUES (case when :1<1 then null else :1 end ,:2)";
2、各使用各的接口
内容概要:本文档聚焦于基于Peng-Robinson状态方程的化工热力学计算研究,系统介绍了利用Matlab代码实现纯组分及多组分系统的压缩因子(z因子)和逸度系数的计算方法,并进一步拓展至泡点压力与露点压力的数值求解。资源涵盖了从状态方程推导、非线性方程求根、相平衡条件判断到迭代算法实现的完整技术路线,提供了可运行的Matlab程序代码,有助于深入理解实际工程中物性参数的计算原理与实现过程; 适合人群:具备化工热力学基础知识和一定Matlab编程能力的高校学生、科研人员及工程技术人员,尤其适合从事过程系统模拟、油气田开发、精馏设计及相关领域研究的专业人士; 使用场景及目标:① 掌握Peng-Robinson方程在真实气体物性计算中的应用;② 实现多组分混合体系的相平衡计算与泡/露点预测;③ 为Aspen Plus等商用流程模拟软件提供底层算法验证与教学参考;④ 支持科研论文复现、课程设计、毕业设计及工业过程优化中的热力学数据支撑需求; 阅读建议:建议读者结合经典化工热力学教材同步学习,重点理解立方型状态方程的根判别、迭代收敛策略与相平衡准则的数学表达,动手调试并运行所提供的Matlab代码以掌握算法细节,还可将其扩展应用于其他状态方程(如SRK、vdW)的对比分析研究。
内容概要:本文围绕列车-轨道-桥梁交互仿真研究,基于Matlab平台构建数值模型,系统分析列车运行过程中轨道与桥梁结构间的动态相互作用机制。研究涵盖多体动力学建模、耦合系统运动方程求解、边界条件设定及仿真结果可视化等关键环节,重点揭示高速行车条件下基础设施的振动传递规律与力学响应特征。该仿真方法可有效评估结构安全性、舒适性指标及疲劳寿命,为轨道交通工程的设计优化与运维管理提供理论支撑和技术路径。文中配套提供了完整的Matlab代码实现方案及操作说明,便于用户复现、验证和拓展相关研究。; 适合人群:具备Matlab编程基础和结构动力学、车辆动力学等相关专业知识的研究生、科研人员及从事铁路工程、桥梁工程与交通系统安全评估的工程技术人才,尤其适合开展轨道交通耦合振动课题的研究者。; 使用场景及目标:①用于高校与科研机构进行列车-轨道-桥梁耦合系统动力学特性的教学演示与科学研究;②支撑高速铁路桥梁的设计优化、运营安全性评估与减振降噪方案验证;③为复杂交通基础设施的多物理场耦合仿真提供建模思路与代码参考。; 阅读建议:建议读者结合所提供的Matlab代码逐模块深入研读,重点关注系统建模假设、质量-刚度-阻尼矩阵构建方法及数值积分算法的实现细节,同时可通过调整参数进行敏感性分析,进一步掌握仿真模型的适用范围与优化方向。

17,135

社区成员

发帖
与我相关
我的任务
社区描述
Oracle开发相关技术讨论
社区管理员
  • 开发
  • Lucifer三思而后行
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧