首页 > 数据库 >proc c++连接oracle

proc c++连接oracle

时间:2023-06-02 09:33:58浏览次数:46  
标签:EXEC int insertdata c++ extern SQL oracle proc datatable

环境:oracle11g、vs2022

1、编写pc文件

EXEC SQL BEGIN DECLARE SECTION;

struct datatable
{
    int id;
    char name[30];
} data;
EXEC SQL END DECLARE SECTION;
View Code
//#define SQLCA_STORAGE_CLASS extern  //增加该行报错
EXEC SQL INCLUDE connect_oracle.h;
#include <sqlca.h>
#include <iostream>
using namespace std;

EXEC SQL BEGIN DECLARE SECTION;
   char* pid ="scott/tiger@orcl";
   int ids;
EXEC SQL END DECLARE SECTION;


int connectdb(){
    EXEC SQL CONNECT :pid;
    if(sqlca.sqlcode!=0){
        cout<< "connect err "<<sqlca.sqlcode<<endl;
        return sqlca.sqlcode;;
    }
    cout<< "connect ok"<<endl;
    return sqlca.sqlcode;;
}

int selectData(datatable& data){
    EXEC SQL 
    SELECT * INTO :data FROM TEST where id=1;
    return sqlca.sqlcode;
}

int insertData(datatable& data){
    exec sql 
     insert into test(id,name) values (:data.id,:data.name);
    if(sqlca.sqlcode!=0){
        cout<< "insert err "<<sqlca.sqlcode<<endl;
        return sqlca.sqlcode;;
    }
    exec sql commit;
    return sqlca.sqlcode;
}

int updateData(datatable& data){
    exec sql 
     update test set name=:data.name where id=:data.id;
    if(sqlca.sqlcode!=0){
        cout<< "update err "<<sqlca.sqlcode<<endl;
        return sqlca.sqlcode;;
    }
    exec sql commit;
    return sqlca.sqlcode;
}

int deleteData(int id){
    ids =id;
    exec sql
     delete from test where id=:ids;
    if(sqlca.sqlcode!=0){
        cout<< "delete err "<<sqlca.sqlcode<<endl;
        return sqlca.sqlcode;;
    }
    exec sql commit;
    return sqlca.sqlcode;
}

void disconnect(){
    EXEC SQL COMMIT RELEASE;
}
View Code

2、编译pc文件

在dos中执行 proc code=cpp ./connect_oracle.pc

3.在vs新建工程,添加新增的cpp文件

#define SQLCA_STORAGE_CLASS extern

#include <iostream>
#include <sqlca.h>
using namespace std;


struct datatable
{
    int id;
    char name[30];
};

extern int connectdb();
extern int selectData(datatable& data);
extern int insertData(datatable& data);
extern int updateData(datatable& data);
extern int deleteData(int id);
extern void disconnect();


int main() {
    connectdb();
    datatable da;
    selectData(da);

    datatable insertdata;
    insertdata.id = 2;

    strcpy(insertdata.name, "bbb");
    insertData(insertdata);

    strcpy(insertdata.name, "ccc");
    updateData(insertdata);

    deleteData(2);


    disconnect();
    return 0;
}
View Code

 

标签:EXEC,int,insertdata,c++,extern,SQL,oracle,proc,datatable
From: https://www.cnblogs.com/ZJ199012/p/17450882.html

相关文章

  • [C++学习]关键字
    const关键字const关键字表示该数据类型的值只读,不可赋值,也就意味着它必须初始化。const若是修饰常量,则只读变量的值会放在“符号常量表”中,而不会立即开辟空间,当数据取地址时则会开辟空间。constintdata=100;int*p=(int*)&data;//开辟空间,p指向该空间。*p=200......
  • Mysql && Oracle 纵向拼接,多行合并为一行
    纵向合并MysqlGROUP_CONCAT函数用法:GROUP_CONCAT(合并的字段名orderby排序字段SEPARATOR分割符)方式一:只合并GROUP_CONCAT(stu.NAME)方式二:带排序GROUP_CONCAT(stu.NAMEORDERBYs.scoreDESC)方式三:带分割符GROUP_CONCAT(stu.NAMEORDERBYs.scoreDESCSEPA......
  • C++字符转码(GBK和UTF8)
    std::stringGB2312ToUtf8(constchar*pSrc,intnLen){stringstrOut;if(pSrc&&nLen>0){//ANSI->UNICODEintlen=MultiByteToWideChar(CP_ACP,0,(LPCTSTR)pSrc,nLen,NULL,0);WCHAR*wszUtf8=new......
  • C++面试八股文:C++中指针、引用、解引用和取地址有什么不同?
    某日小二参加XXX科技公司的C++工程师开发岗位2面:面试官:指针、引用、解引用和取地址是C++中的重要概念,请问它们在语法和语义上有所不同?小二:指针是一个变量,它存储了一个内存地址。小二:引用是一个别名,它允许使用一个变量的多个名称来访问同一个内存位置。小二:解引用是指使用*运......
  • 深入探索C++对象模型(十一)执行期语义学(临时对象)
    关于临时对象的几条准则。1. 在某些情况下,编译器可以产生必要的,或者可以带来方便的临时对象,具体行为由编译器来定义。例如,对于如下操作:1.Ta,b;2.Tc=a+b;//Toperator+(constT&,constT&)a.编译器会产生一个临时对象,放置a+b的结果,然后使用T的拷贝构造函数,把临时......
  • C++温故补缺(二十):杂项补充1
    杂记1布尔型c语言中表示布尔型一般用0/1,或者flag,c++把布尔型内置了,布尔型的变量只有true和false两个值和0/1的关系:true和false不是0/1,c++编译器会把非0处理成true,把0处理成false宽字符型char型只有一个字节的长度,如果要在c中表示汉字,则需要使用字符串数组c++添加......
  • C++中 字符串的常见操作
    字符串分割在一些比较流行的语言中,字符串分割是一个比较重要的方法,不论是在python,java这样的系统级语言还是js这样的前端脚本都会在用到字符串的分割,然而在c++中却没有这样的方法用来调用。但是在boost中却提供分割方法。使用vector实现下面是用vector实现的一个简单的split......
  • C++ 中的运算符优先级
     运算符的优先级确定表达式中项的组合。这会影响到一个表达式如何计算。某些运算符比其他运算符有更高的优先级,例如,乘除运算符具有比加减运算符更高的优先级。例如x=7+3*2,在这里,x被赋值为13,而不是20,因为运算符*具有比+更高的优先级,所以首先计算乘法3*2,然后再加......
  • C++ 循环
     有的时候,可能需要多次执行同一块代码。一般情况下,语句是顺序执行的:函数中的第一个语句先执行,接着是第二个语句,依此类推。编程语言提供了允许更为复杂的执行路径的多种控制结构。循环语句允许我们多次执行一个语句或语句组,下面是大多数编程语言中循环语句的一般形式:https:/......
  • C++中的map用法学习
    map是STL的一个关联容器,它提供一对一的hash。第一个可以称为关键字(key),每个关键字只能在map中出现一次;第二个可能称为该关键字的值(value);map以模板(泛型)方式实现,可以存储任意类型的数据,包括使用者自定义的数据类型。Map主要用于资料一对一映射(one-to-one)的情況,map內部的......