vc查询oracle数据库操作,VC在控制台模式下访问Oracle数据库的操作指令

#include

#include

#import "C:\Program Files\Common Files\System\ADO\msado15.dll" no_namespace rename("EOF","adoEOF")

using namespace std;

#define BUFSIZE 64

int main()

{

//char buf[BUFSIZE];

//int index;

_ConnectionPtr m_pConnection;

CoInitialize(NULL);//初始化COM组件

HRESULT hr=m_pConnection.CreateInstance(__uuidof(Connection));

if(SUCCEEDED(hr))

{

cout<

}

try

{

_bstr_t strConnect="Provider=OraOLEDB.Oracle;User ID=scott;Password=19900624;Persist Security Info=True;Data Source=\"(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)(HOST = 10.108.85.137)(PORT = 1521)) )(CONNECT_DATA = (SID = ORCL)(SERVER=DEDICATED)))\"";

hr=m_pConnection->Open(strConnect,"","",NULL);

if(SUCCEEDED(hr))

cout<

}

catch(_com_error e) //捕捉异常

{

cout<

//cout<

return FALSE;

}

/查询数据库操作//

_variant_t var1;

_RecordsetPtr m_pRecordset=NULL; //创建一个数据集智能指针

m_pRecordset.CreateInstance(__uuidof(Recordset));//初始化Recordset指针

char *content;

char type;

cin>>type;

switch(type)

{

case 's':

try

{

CString sql;

sql="select * from DB_USER";

m_pRecordset=m_pConnection->Execute((_bstr_t)sql,NULL,adCmdText);

}

catch(_com_error *e)

{

cout<ErrorMessage()<

}

try

{

if(!m_pRecordset->BOF)

{

m_pRecordset->MoveFirst();

}

else

{

cout<

}

while(!m_pRecordset->adoEOF)

{

//var1=m_pRecordset->Fields->GetItem("USERNAME")->GetValue();

var1=m_pRecordset->GetCollect("USERNAME");

m_pRecordset->MoveNext();

if(var1.vt!=VT_NULL)

{

content=_com_util::ConvertBSTRToString((_bstr_t)var1);

}

cout<

}

}

catch(_com_error *e)

{

cout<ErrorMessage()<

}

break;

case 'd':

try

{

_variant_t RecordsAffected;

CString sql;

sql="delete * from DB_USER where USERID='3'";

m_pConnection->Execute((_bstr_t)sql,&RecordsAffected,adCmdText);

cout<

}

catch(_com_error *e)

{

cout<ErrorMessage()<

return 0;

}

break;

case 'u':

try

{

_variant_t RecordsAffected;

CString sql;

sql="update DB_USER set EMAIL='cupt5634@126.com' where USERID=1";

m_pConnection->Execute((_bstr_t)sql,&RecordsAffected,adCmdText);

cout<

break;

}

catch(_com_error *e)

{

cout<ErrorMessage()<

return 0;

}

case 'a':

try

{

_variant_t RecordsAffected;

CString sql;

sql="insert into DB_USER (USERNAME,PWD1,SEX,EMAIL,USERID)values ('Allen','1235698','女','698797@qq.com','3')";

m_pConnection->Execute((_bstr_t)sql,&RecordsAffected,adCmdText);

cout<

}

catch(_com_error *e)

{

cout<ErrorMessage()<

return 0;

}

break;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值