使用C++操作数据库,转换返回结果集为json格式,易于解析。

以下程序的编译、运行环境:Windows 10 1803、VS2017 17.5.2(vc14)、解决方案配置:Release、解决方案平台:X86

 #include <iostream>
#include <occi.h>
#include <json.h>
#pragma comment(lib,"oraocci12.lib")
#pragma comment(lib,"json_vc71_libmt.lib")
using namespace std;
using namespace oracle::occi; int main()
{
  //初始化occi对象
  Environment *env = NULL;
  Connection *conn = NULL;
  Statement *stmt = NULL;
  ResultSet *res = NULL;   try
  {
    char usrName[] = "shaqima";
    char usrPwd[] = "userpwd";
    char connectStr[] = "10.10.82.25:1521/orcl";
    //创建连接环境
    env = Environment::createEnvironment();
    //连接到数据库
    conn = env->createEnvironment(usrName,usrPwd,connectStr);
    if(!conn)
    {
      cout <<"error: connect failed!"<<endl;
      return ;
    }     //oracle sql语句
    char sqlStr[] = "select * from DEVICE_INFO t where t.ID=:1";
    stmt = conn->createStatement(sqlStr);
    //设置sql变量
    stmt->setString(,"");
    //执行sql
    res = stmt->executeQuery();     //初始化jsoncpp对象
    Json::Reader reader;
    //根节点
    Json::Value rootNode;
    //子节点
    Json::Value childNode;     int nodeNum = ;
    //查询出结果集,并存入json节点
    while(res->next())
    {
      childNode["Id"] = res->getInt();
      childNode["AssetCode"] = res->getString();
      childNode["EncryptDrive"] = res->getString();
      //将子节点挂载到根节点
      rootNode[nodeNum] = Json::Value(childNode);
      nodeNum++;
    }     cout<<"使用.toStyledString()转换为标准json格式:"<<endl;
    cout<<rootNode.toStyledString()<<endl;     Json::FastWriter fw;
    cout<<"转换成易于传输的josn字符串格式"<<endl;
    cout<<fw.write(rootNode)<<endl;
  }
  catch(SQLException ex)
  {
    cout<<"ErrorCode:"<<ex.getErrorCode()<<endl;
    cout<<"ErrorMsg:"<<ex.getMessage()<<endl;
  }
  //释放资源
  stmt->closeResultSet(res);
  conn->terminateStatement(stmt);
  env->terminateConnection(conn);
  Environment::terminateEnvironment(env);   system("pause");
  return ;
}

新手指路:

1、occi.h从Oracle instantclient-sdk-12.2.0.1.0中可获得。

OCCI 头文件包括:occi.h、occiCommon.h、occiControl.h、occiData.h、occiObjects.h,将所有文件置于同一引用目录下,项目中只需要引用occi.h即可。

2、oraocci12.lib是静态库,从Oracle instantclient-sdk-12.2.0.1.0中可获得,使用vc14目录下的oraocci12.lib。

3、我使用的是开源jsoncpp,从https://sourceforge.net/projects/jsoncpp/下载,jsoncpp头文件在jsoncpp-src-0.5.0/include/json下将所有文件置于同一引用目录下,项目中只需要引用json.h即可。

4、需要在本地计算机编译以获得json_vc71_libmt.lib,打开jsoncpp-src-0.5.0/makefiles/vs71/jsoncpp.sln项目,lib_json右键-属性,设置编译环境:

①“配置属性-常规-Windows SDK版本”,与项目设置一致

②“配置属性-常规-全程序优化”,设置为:无全程序优化

③“配置属性-C/C++-所有选项-运行库”,与项目设置一致

④解决方案配置、解决方案平台,与项目设置一致

编译成功后,在jsoncpp-src-0.5.0/build/vs71/release/lib_json/下为编译之后的文件(debug/下的为json_vc71_libmtd.lib),其中的.obj、.asm文件必须与.lib文件在同一目录下,请注意。

使用C++ OCCI API 增、删、改日后再研究~

C++ OCCI API数据库操作之连接、返回查询结果集为json格式的更多相关文章

  1. SQL SERVER C#数据库操作类(连接、执行SQL)

    using System; using System.Collections; using System.Collections.Specialized; using System.Data; usi ...

  2. laravel 连接同一服务器上多个数据库操作 、 连接多个不同服务器上的不同数据库操作以及多个数据库操作的事务处理

    !注意:标红的要注意区分开 第一步.配置.env文件(同一服务器上多个数据库) DB_CONNECTION=pgsqlDB_HOST=IP(例如:127.0.0.1)DB_PORT=端口号(例如:54 ...

  3. 将 数据库中的结果集转换为json格式(三)

    从数据库中得到结果集 public String list() throws Exception { Connection con = null; PageBean pageBean = new Pa ...

  4. PHP中把数据库查询结果输出为json格式

    <?php header("Content-type:text/html;charset=utf-8");//字符编码设置 $servername = "local ...

  5. Python入门学习教程:数据库操作,连接MySql数据库

    各位志同道合的同仁可以点击上方关注↑↑↑↑↑↑ 本教程致力于程序员快速掌握Python语言编程. 本文章内容是基于上次课程Python教程:Python教程:连接数据库,对数据进行增删改查操作 和py ...

  6. 解决阿里云轻量级服务器mysql无法用数据库操作软件连接

    第一步:去阿里云购买一台轻量应用服务器Lamp然后登录到控制台点击应用详情 点击后你可以看到一些服务器的数据 首先是访问服务器的首页地址,默认会放一个html文件在网站根目录下(即/home/www/ ...

  7. JAVA数据库处理(连接,数据查询,结果集返回)

    package john import java.io.IOException; import java.util.*; public class QueryDataRow { public Hash ...

  8. laravel 数据库操作之 DB facade & 查询构造器 & Eloquent ORM

    <?php namespace App\Http\Controllers; use App\Student; use Illuminate\Support\Facades\DB; class S ...

  9. yii学习笔记(7),数据库操作,联表查询

    在实际开发中,联表查询是很常见的,yii提供联表查询的方式 关系型数据表:一对一关系,一对多关系 实例: 文章表和文章分类表 一个文章对应一个分类 一个分类可以对应多个文章 文章表:article 文 ...

随机推荐

  1. [SoapUI] 在SoapUI中通过Groovy脚本执行window命令杀掉进程

    //杀Excel进程 String line def p = "taskkill /F /IM EXCEL.exe".execute() def bri = new Buffere ...

  2. Python编程笔记(第三篇)【补充】三元运算、文件处理、检测文件编码、递归、斐波那契数列、名称空间、作用域、生成器

    一.三元运算 三元运算又称三目运算,是对简单的条件语句的简写,如: 简单条件处理: if 条件成立: val = 1 else: val = 2 改成三元运算 val = 1 if 条件成立 else ...

  3. Python导入自定义类时显示错误:attempted relative import beyond top-level package

    显示这个错误可能有两个原因: 1.文件夹中没有包含__init__.py文件,该文件可以为空,但必须存在该文件. 2.把该文件当成主函数入口,该文件所在文件夹不能被解释器视作package,所以可能导 ...

  4. 69.查看APP沙盒缓存的内容文件

    第一步:链接真机设备,点击Xcode ,按command+shift+2  弹出电脑所运行的APP列表 第二步:选中你需要查看的APP,点击最下面! 类似于设置图标的按钮! 点击第二个Download ...

  5. spring boot中注入jpa时报could not autowire.No beans of 'PersonRepository' type found

    解决方法,在repository加一个注解.如下图所示: @Component

  6. 2019.01.24 bzoj3125: CITY(轮廓线dp)

    传送门 题意简述:给一个n∗mn*mn∗m的网格图,有的格子不能走,有的格子只能竖着走,有的格子只能横着走,问用一条回路覆盖所有能走的格子的方案数. 思路: 就是简单的轮廓线dpdpdp加了一点限制而 ...

  7. Java核心技术之类与对象

    知识点 1. 一个对象变量并没有实际包含一个对象,而仅仅引用一个对象.new操作符的返回值也是一个引用. 2. 局部变量不会自动地初始化为null,而必须用过调用new或将他们设置为null进行初始化 ...

  8. react组件父传子

    react组件父传子,子组件使用父组件的数据,用props import React, { Component } from 'react'; class App extends Component ...

  9. 一个WCF 数据序列化问题

    public class EMMPBaseMsg { public String Data { get; set; } public DateTime AddTime { get; set; } pu ...

  10. s4-7 生成树协议

    Spanning Tree :为了可靠,采用冗余结构:但是透明网桥 会产生无休止循环的问题 冗余交换拓扑可能带来的问题  广播风暴  多帧传送  MAC地址库不稳定 生成树协议  STP:sp ...