有上篇文章已经说了odb的环境编译, 现在直接拿来给的例子进行数据库的增删改查操作测试

1. ODB访问oracle数据库_ 插入操作(insert)

  直接运行上篇编译好的exe文件会出现如下错误

  

错误原因: 已经提示的很清楚了

解决方法: 要告诉程序访问数据库的登录名, 密码, 数据库名, ip地址, 端口号

代码:

只要将auto_ptr<database> db (create_database (argc, argv));

改成:

auto_ptr<odb::database> db( new odb::oracle::database("system", "sa",  "ORCL", "127.0.0.1",1521)); //各种数据库写法都是改

如下图:

执行程序前, 数据库无记录

执行后,数据库信息(我的id从19开始, 因为我在此之前删除了18条记录)

执行插入步骤如下:

  1. auto_ptr<odb::database> db( new odb::oracle::database( "system", "sa",   "ORCL", "127.0.0.1", 1521 ));

    2. person john ("John", "John_Doe", 33);

    3. transaction t (db->begin ());

    4. db->persist (john);

    5.t.commit ();

 2. odb访问oracle数据库操作_查找记录(select)

  A.  无条件查询记录如下

  

B. 条件查询结果如下

  1. auto_ptr<odb::database> db( new odb::oracle::database( "system",  "sa",   "ORCL",  "127.0.0.1", 1521  ));

  2. typedef odb::query<person> query;

   typedef odb::result<person> result;

  3. transaction t (db->begin ());

  4.result r (db->query<person>());//无条件查询

  //result r (db->query<person>(query::last == "Joe_Dirt36"));//条件查询

  5.for (result::iterator i (r.begin ()); i != r.end (); ++i){

    cout << i->first () << " " << i->last () <<" " << i->age() << "!" << endl;}

  6.t.commit ();

3. ODB访问oracle数据库_更新操作(update)

更新前:

更新后:

执行更新操作步骤

  1. auto_ptr<odb::database> db( new odb::oracle::database("system", "sa",  "ORCL", "127.0.0.1",1521  ));

  2. transaction t (db->begin ());

  3. unsigned long  id = 26;

  auto_ptr<person> joe (db->load<person>(id));

  joe->age (joe->age () + 100);

  4. db->update (*joe);

  5. t.commit ();

4. 访问Oracle数据库_删除操作(earse)

删除操作前

删除操作后

删除操作步骤:

  1. auto_ptr<odb::database> db( new odb::oracle::database("system",  "sa", "ORCL",   "127.0.0.1",  1521 ));

  2. transaction t (db->begin ());

  3. unsigned long john_id = 26;

  4. db->erase<person> (john_id);

  5. t.commit ();

Window ODB环境编译: https://www.cnblogs.com/hul201610101100/p/9482311.html

C++版本 ORM 访问数据库之ODB 的oracle Demo测试(二)的更多相关文章

  1. C++版本 ORM 访问数据库之ODB 的Window环境编译(一)

    先简单说说我为什么要编译一个ORM访问数据库的版本, 以前在做C#访问数据库时候, 直接以orm方式访问数据库, 代码写起来简单,  不用写各种复杂的sql语句, 直接有orm框架生成, 后来转到C+ ...

  2. C++ 版本ORM访问数据库之ODB访问oracle的Demo(三)

    ODB的组成部分: 1: 操作系统的ODB编译器 2: odb核心库libodb 3: 各种数据库的相关链接库 使用ODB访问数据需要的库和头文件(不懂, 请看https://www.cnblogs. ...

  3. 用dotnet core搭建web服务器(三)ORM访问数据库

    访问传统sql数据库,大家以前都是用sql语句去查询.这些年流行orm方法 ORM是对象关系映射的简拼,就是用一个对象(class)去表示数据的一行,用对象的成员去表述数据的列 dotnet 官方很早 ...

  4. 【一】ODB - C++ 访问数据库的利器--Hello World On Windows(Version-24)

    本文以MySQL数据库为例,其他数据类似. 官方文档和下载 ODB官方首页    官方开发者说明书(开发教程) 安装下载首页(下载与安装教程Windows/Linux) Windows安装步骤(都是英 ...

  5. [开源] .Net 使用 ORM 访问 达梦数据库

    前言 武汉达梦数据库有限公司成立于2000年,为中国电子信息产业集团(CEC)旗下基础软件企业,专业从事数据库管理系统的研发.销售与服务,同时可为用户提供大数据平台架构咨询.数据技术方案规划.产品部署 ...

  6. Python与数据库[2] -> 关系对象映射/ORM[3] -> sqlalchemy 的声明层 ORM 访问方式

    sqlalchemy的声明层ORM访问方式 sqlalchemy中可以利用声明层进行表格类的建立,并利用ORM对象进行数据库的操作及访问,另一种方式为显式的 ORM 访问方式. 主要的建立步骤包括: ...

  7. Python与数据库[2] -> 关系对象映射/ORM[4] -> sqlalchemy 的显式 ORM 访问方式

    sqlalchemy 的显式 ORM 访问方式 对于sqlalchemy,可以利用一种显式的ORM方式进行访问,这种方式无需依赖声明层,而是显式地进行操作.还有一种访问方式为声明层 ORM 访问方式. ...

  8. VS2017新建MVC+ORM中的LinqDb访问数据库项目

    1.前提概述 ORM对象关系映射(Object-Relational Mapping)是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换.从效果上说,它其实是创建了一个可在编程语言 ...

  9. Spring实战6:利用Spring和JDBC访问数据库

    主要内容 定义Spring的数据访问支持 配置数据库资源 使用Spring提供的JDBC模板 写在前面:经过上一篇文章的学习,我们掌握了如何写web应用的控制器层,不过由于只定义了SpitterRep ...

随机推荐

  1. SourceTree 版本跳过bitbucket注册方法

    1.安装sourcetree时 需要选择 bitbucket账号,这个令人头疼 当然肯定有办法来跳过这一步 2.关闭当前安装界面 进入   C:\Users\Administrator\AppData ...

  2. [线段树]区间修改&区间查询问题

    区间修改&区间查询问题 [引言]信息学奥赛中常见有区间操作问题,这种类型的题目一般数据规模极大,无法用简单的模拟通过,因此本篇论文将讨论关于可以实现区间修改和区间查询的一部分算法的优越与否. ...

  3. ssh工具推荐MobaXterm 可能是你遇到过的比较出色的一款

    之前一直用xshell,现在推荐一个更好用的工具. 一站式的解决你的需求,而且画风个人也比较喜欢,而且随便一百度就能找得到green PJ 的版本

  4. consul实现kubernetes-1.15集群master的高可用访问实现

    1.准备consul环境,参考我之前的博客实现或参考consul的官网部署最新的consul. 2.本次测试使用的是kubernetes-1.15.0 3.初始化集群 1)准备初始化文件 contro ...

  5. Xamarin移动开发备忘

    vs2017下: 1.debug用于本地生成和调试,release用于发布.区别主要在于: 安卓项目的生成选项属性中,开发者模式release是不勾的,而且高级里的cpu不同(debug是x86,re ...

  6. Javaweb常用解决问题连接

    1.javaweb的idea如何创建及配置web项目 https://www.jianshu.com/p/8d49d36a3c7e 2.servlet的建立以及部署 https://blog.csdn ...

  7. 如何使用Charles让手机访问PC自定义域名?

    需求:移动端访问PC上的自定义域名,如在Nginx上配置的域名 ​ 如vv.zzcloud.com这个域名在pc上是通过host映射的方式访问,现在需要在手机上访问到这个域名. 工具:Charles代 ...

  8. 多个python版本共存时的pip配置

    两种方法来配置pip Func1: 1.1 找到python环境的安装包,将python.exe文件重命名,如:将python2.7版本的python.exe重命名为Python2.exe,将pyth ...

  9. Django框架(二十)-- Django rest_framework-权限组件

    一.权限组件的使用 # 用户信息表 class UserInfo(models.Model): name = models.CharField(max_length=32) # 写choice use ...

  10. [小程序]微信小程序登陆并获取用户信息

    1.小程序js端调用框架登陆API,获取到一个临时code,拿着这个code去调用自己的服务端接口 2.在自己的服务器端,使用app_id app_secrect code可以获取到用户的openid ...