OCILIB 连接Oracle数据库——插入数据

( CSDN格式不友好,同样的内容请参考:简书 )

二、进阶教程

参看官方文档实例,有详细的说明,包括:查询获取数据、绑定向量、数据库连接池、12c隐式结果集、使用Oracle对象和数据库通知等例子。这里只做一个最简单的插入数据演示。

1、简单的封装

void COciUtil::Init()
{
	CString strAppPath = CMyFileUtil::GetAppPathW();//获得程序运行目录
	ostring ociDllPath = CW2A(strAppPath);
	try
	{
		Environment::Initialize(Environment::Default,ociDllPath);
    }
 	catch (std::exception& e)
	{
		CString text(e.what());
		AfxMessageBox(text);
	}
}

void COciUtil::Clean()
{
	try
	{
		conn.Close();
		Environment::Cleanup();
	}
	catch (std::exception& e)
	{
		CString text(e.what());
		AfxMessageBox(text);
	}
}

BOOL COciUtil::Connect(CString ip,int port,CString serviceName,CString username,CString password)
{
	try
	{
		CString strDB;
		strDB.Format(L"%s:%d/%s",ip,port,serviceName);
		char* db = CW2A(strDB);
		char* user = CW2A(username);
		char* pw = CW2A(password);
		conn.Open(db,user,pw);

		if (conn.IsNull())
			return FALSE;
		else
			return TRUE;
	}
	catch (std::exception& e)
	{
		CString text(e.what());
		AfxMessageBox(text);
		return FALSE;
	}
}

2、插入数据库

这里向数据库中插入数字、文本、时间、二进制。

BOOL COciDao::InsertTest()
{
	try
	{
		COciUtil oci;
		ocilib::Statement st(oci.conn);
		st.Prepare("insert into TEST(ID,TEXT,TIME,BIN) values ( :id , :text , :date , :blob )");
		
		int id = 123;
		char* binaryText = "eee向天歌浮绿水";
		ocilib::Blob blob(oci.conn);

		vector<BYTE> list;
		list.resize(strlen(binaryText));
		for (int i=0;i<strlen(binaryText);i++)
		{
			list.push_back(binaryText[i]);
		}
		blob.Write(list);

		ostring ostr = "texttexttext";
		COleDateTime time = COleDateTime::GetCurrentTime();
		ocilib::Date date = COleDateTime2Date(time);

		st.Bind<int>(":id",id,BindInfo::InOut);
		st.Bind<ostring,int>(":text",ostr,50,BindInfo::InOut);
		st.Bind<Date>(":date",date,BindInfo::InOut);
		st.Bind<Blob>(":blob",blob,BindInfo::InOut);

		st.ExecutePrepared();
		oci.conn.Commit();
		oci.Clean();
	}
	catch (std::exception &e) 
	{
		//cout<<e.what()<<endl;
		CString text(e.what());
		AfxMessageBox(text);
	}
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值