ADO:实现向Oracle数据库中插入数据

简介: ADO:实现向Oracle数据库中插入数据 1、使用Command对象完成插入。 Command 对象定义了将对数据源执行的指定命令。该对象中常用的属性和方法如下: ⑴ ActiveConnection 属性:该属性指定 Command 对象当前所属的 Connection 对象; ⑵ CommandText 属性:该属性包含发送给数据提供者的命令文本,该属性的值可以是 SQL 语句、表名 或 存储过程名 的字符串。

ADO:实现向Oracle数据库中插入数据

1、使用Command对象完成插入。

Command 对象定义了将对数据源执行的指定命令。该对象中常用的属性和方法如下:
⑴ ActiveConnection 属性:该属性指定 Command 对象当前所属的 Connection 对象;
⑵ CommandText 属性:该属性包含发送给数据提供者的命令文本,该属性的值可以是 SQL 语句、表名 或 存储过程名 的字符串。
⑶ CommandType 属性:指示 Command 对象的属性,其值可以取 CommandTypeEnum 中的某个值,取值类似 Recordset 对象的 Open 方法的 Options 参数。
⑷ Execute 方法:执行在 CommandText 属性中指定的查询、SQL 语句 或 存储过程。

使用 Command 对象的过程步骤:
⑴ 定义 _CommandPtr 型变量;
⑵ 实例化变量;
⑶ 设置变量的相关属性;

⑷ 调用 Execute 方法执行命令。

实例代码:

[html] view plain copy

  1. /*
  2.     功能:使用 Command 对象向数据库中插入数据
  3. */
  4. BOOL CRentDVDDlg::RentDVDByCommand(CString& strDVDID, CString& strRentName, CString& strRentDate)
  5. {
  6.     BOOL bRet = FALSE;
  7.     HRESULT hr;
  8.     /*实例化一个Command对象*/
  9.     _CommandPtr pCommand;
  10.     hr = pCommand.CreateInstance(__uuidof(Command));
  11.     if(FAILED(hr))
  12.     {
  13.         MessageBox(_T("RentDVDByCommand:Command对象实例化失败!"));
  14.         return FALSE;
  15.     }
  16.     /*关联当前连接*/
  17.     pCommand->ActiveConnection = m_pConnection;
  18.     /*组串*/
  19.     CString strSQL;
  20.     strSQL.Format(_T("insert into tbRentInfo(sDVDID,sName,sDate) values(\'%s\',\'%s\',\'%s\')"), strDVDID, strRentName, strRentDate);
  21.     pCommand->CommandText =_bstr_t(strSQL);
  22.     /*执行插入操作*/
  23.     try
  24.     {
  25.         _variant_t vRecords;
  26.         hr = pCommand->Execute(&vRecords,NULL,adCmdText);
  27.         if (SUCCEEDED(hr))
  28.         {
  29.             bRet = TRUE;
  30.         }
  31.     }
  32.     catch(_com_error *e)
  33.     {
  34.         MessageBox(e->ErrorMessage());
  35.     }
  36.     return bRet;
  37. }

2、使用Connection对象完成插入数据的操作,与上一种比较类似:

[html] view plain copy

  1. /*
  2.     功能:使用 Connection 对象向数据库中插入数据
  3. */
  4. BOOL CRentDVDDlg::RentDVDByConnection(CString& strDVDID, CString& strRentName, CString& strRentDate)
  5. {
  6.     BOOL bRet = FALSE;
  7.     HRESULT hr;
  8.     /*组串*/
  9.     CString strSQL;
  10.     strSQL.Format(_T("insert into tbRentInfo(sDVDID,sName,sDate) values(\'%s\',\'%s\',\'%s\')"), strDVDID, strRentName, strRentDate);
  11.     /*执行插入操作*/
  12.     try
  13.     {
  14.         _variant_t vRecords,RecordsAffected;
  15.         hr = m_pConnection->Execute(_bstr_t(strSQL), &RecordsAffected, adCmdText);
  16.         if (SUCCEEDED(hr))
  17.         {
  18.             bRet = TRUE;
  19.         }
  20.     }
  21.     catch(_com_error *e)
  22.     {
  23.         MessageBox(e->ErrorMessage());
  24.     }
  25.     return bRet;
  26. }

3、使用RecordSet对象完成插入数据操作,RecordSet对象的使用前面文章有介绍:

[html] view plain copy

  1. /*
  2.     功能:使用 Connection 对象向数据库中插入数据
  3. */
  4. BOOL CRentDVDDlg::RentDVDByConnection(CString& strDVDID, CString& strRentName, CString& strRentDate)
  5. {
  6.     BOOL bRet = FALSE;
  7.     HRESULT hr;
  8.     /*组串*/
  9.     CString strSQL;
  10.     strSQL.Format(_T("insert into tbRentInfo(sDVDID,sName,sDate) values(\'%s\',\'%s\',\'%s\')"), strDVDID, strRentName, strRentDate);
  11.     /*执行插入操作*/
  12.     try
  13.     {
  14.         _variant_t vRecords,RecordsAffected;
  15.         hr = m_pConnection->Execute(_bstr_t(strSQL), &RecordsAffected, adCmdText);
  16.         if (SUCCEEDED(hr))
  17.         {
  18.             bRet = TRUE;
  19.         }
  20.     }
  21.     catch(_com_error *e)
  22.     {
  23.         MessageBox(e->ErrorMessage());
  24.     }
  25.     return bRet;
  26. }
相关文章
|
3天前
|
存储 Oracle 关系型数据库
服务器数据恢复—光纤存储上oracle数据库数据恢复案例
一台光纤服务器存储上有16块FC硬盘,上层部署了Oracle数据库。服务器存储前面板2个硬盘指示灯显示异常,存储映射到linux操作系统上的卷挂载不上,业务中断。 通过storage manager查看存储状态,发现逻辑卷状态失败。再查看物理磁盘状态,发现其中一块盘报告“警告”,硬盘指示灯显示异常的2块盘报告“失败”。 将当前存储的完整日志状态备份下来,解析备份出来的存储日志并获得了关于逻辑卷结构的部分信息。
|
3月前
|
存储 缓存 数据库
数据库数据删除策略:硬删除vs软删除的最佳实践指南
在项目开发中,“删除”操作常见但方式多样,主要分为硬删除与软删除。硬删除直接从数据库移除数据,操作简单、高效,但不可恢复;适用于临时或敏感数据。软删除通过标记字段保留数据,支持恢复和审计,但增加查询复杂度与数据量;适合需追踪历史或可恢复的场景。两者各有优劣,实际开发中常结合使用以满足不同需求。
223 4
|
13天前
|
存储 Oracle 关系型数据库
【赵渝强老师】Oracle RMAN的目录数据库
Oracle RMAN默认将备份元信息存储在控制文件中,但控制文件损坏或丢失会导致恢复失败,且备份增多会使控制文件无限增长。为解决这些问题,Oracle引入了RMAN目录数据库(Catalog Database),专门用于存储RMAN备份的元信息。使用目录数据库可提升备份管理效率,支持多数据库共享、长期备份历史记录存储,并可保存RMAN脚本。本文详细介绍了如何创建目录数据库、注册目标数据库及其操作步骤。
|
1月前
|
存储 SQL Java
数据存储使用文件还是数据库,哪个更合适?
数据库和文件系统各有优劣:数据库读写性能较低、结构 rigid,但具备计算能力和数据一致性保障;文件系统灵活易管理、读写高效,但缺乏计算能力且无法保证一致性。针对仅需高效存储与灵活管理的场景,文件系统更优,但其计算短板可通过开源工具 SPL(Structured Process Language)弥补。SPL 提供独立计算语法及高性能文件格式(如集文件、组表),支持复杂计算与多源混合查询,甚至可替代数据仓库。此外,SPL 易集成、支持热切换,大幅提升开发运维效率,是后数据库时代文件存储的理想补充方案。
|
1月前
|
存储 Oracle 关系型数据库
oracle数据恢复—oracle数据库执行错误truncate命令的数据恢复案例
oracle数据库误执行truncate命令导致数据丢失是一种常见情况。通常情况下,oracle数据库误操作删除数据只需要通过备份恢复数据即可。也会碰到一些特殊情况,例如数据库备份无法使用或者还原报错等。下面和大家分享一例oracle数据库误执行truncate命令导致数据丢失的数据库数据恢复过程。
|
3月前
|
Oracle 安全 关系型数据库
【Oracle】使用Navicat Premium连接Oracle数据库两种方法
以上就是两种使用Navicat Premium连接Oracle数据库的方法介绍,希望对你有所帮助!
690 28
|
3月前
|
SQL Oracle 关系型数据库
【赵渝强老师】Oracle的闪回数据库
Oracle闪回数据库功能类似于“倒带按钮”,可快速将数据库恢复至 earlier 状态,无需还原备份。本文介绍了闪回数据库的使用方法及实战案例:包括设置归档模式、开启闪回功能、记录SCN号、执行误操作后的恢复步骤等。通过具体 SQL 操作演示了如何利用闪回数据库恢复被误删的用户数据。注意,使用此功能前需确保数据库为归档模式。
123 9
|
3月前
|
人工智能 关系型数据库 分布式数据库
让数据与AI贴得更近,阿里云瑶池数据库系列产品焕新升级
4月9日阿里云AI势能大会上,阿里云瑶池数据库发布重磅新品及一系列产品能力升级。「推理加速服务」Tair KVCache全新上线,实现KVCache动态分层存储,显著提高内存资源利用率,为大模型推理降本提速。
|
11月前
|
监控 Oracle 关系型数据库
"深度剖析:Oracle SGA大小调整策略——从组件解析到动态优化,打造高效数据库性能"
【8月更文挑战第9天】在Oracle数据库性能优化中,系统全局区(SGA)的大小调整至关重要。SGA作为一组共享内存区域,直接影响数据库处理能力和响应速度。本文通过问答形式介绍SGA调整策略:包括SGA的组成(如数据缓冲区、共享池等),如何根据负载与物理内存确定初始大小,手动调整SGA的方法(如使用`ALTER SYSTEM`命令),以及利用自动内存管理(AMM)特性实现智能调整。调整过程中需注意监控与测试,确保稳定性和性能。
740 2

推荐镜像

更多