C++版本 ORM 访问数据库之ODB 的oracle Demo测试(二)
有上篇文章已经说了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条记录)

执行插入步骤如下:
- 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测试(二)的更多相关文章
- C++版本 ORM 访问数据库之ODB 的Window环境编译(一)
先简单说说我为什么要编译一个ORM访问数据库的版本, 以前在做C#访问数据库时候, 直接以orm方式访问数据库, 代码写起来简单, 不用写各种复杂的sql语句, 直接有orm框架生成, 后来转到C+ ...
- C++ 版本ORM访问数据库之ODB访问oracle的Demo(三)
ODB的组成部分: 1: 操作系统的ODB编译器 2: odb核心库libodb 3: 各种数据库的相关链接库 使用ODB访问数据需要的库和头文件(不懂, 请看https://www.cnblogs. ...
- 用dotnet core搭建web服务器(三)ORM访问数据库
访问传统sql数据库,大家以前都是用sql语句去查询.这些年流行orm方法 ORM是对象关系映射的简拼,就是用一个对象(class)去表示数据的一行,用对象的成员去表述数据的列 dotnet 官方很早 ...
- 【一】ODB - C++ 访问数据库的利器--Hello World On Windows(Version-24)
本文以MySQL数据库为例,其他数据类似. 官方文档和下载 ODB官方首页 官方开发者说明书(开发教程) 安装下载首页(下载与安装教程Windows/Linux) Windows安装步骤(都是英 ...
- [开源] .Net 使用 ORM 访问 达梦数据库
前言 武汉达梦数据库有限公司成立于2000年,为中国电子信息产业集团(CEC)旗下基础软件企业,专业从事数据库管理系统的研发.销售与服务,同时可为用户提供大数据平台架构咨询.数据技术方案规划.产品部署 ...
- Python与数据库[2] -> 关系对象映射/ORM[3] -> sqlalchemy 的声明层 ORM 访问方式
sqlalchemy的声明层ORM访问方式 sqlalchemy中可以利用声明层进行表格类的建立,并利用ORM对象进行数据库的操作及访问,另一种方式为显式的 ORM 访问方式. 主要的建立步骤包括: ...
- Python与数据库[2] -> 关系对象映射/ORM[4] -> sqlalchemy 的显式 ORM 访问方式
sqlalchemy 的显式 ORM 访问方式 对于sqlalchemy,可以利用一种显式的ORM方式进行访问,这种方式无需依赖声明层,而是显式地进行操作.还有一种访问方式为声明层 ORM 访问方式. ...
- VS2017新建MVC+ORM中的LinqDb访问数据库项目
1.前提概述 ORM对象关系映射(Object-Relational Mapping)是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换.从效果上说,它其实是创建了一个可在编程语言 ...
- Spring实战6:利用Spring和JDBC访问数据库
主要内容 定义Spring的数据访问支持 配置数据库资源 使用Spring提供的JDBC模板 写在前面:经过上一篇文章的学习,我们掌握了如何写web应用的控制器层,不过由于只定义了SpitterRep ...
随机推荐
- HTML+css基础 css的几种形式
1.行间样式:将style写在标签内的充当标签标签属性 2.行内样式
- VMware workstation 12虚拟机安装CentOS7详细安装教程
虚拟机(Virtual Machine)指通过软件模拟的具有完整硬件系统功能的.运行在一个完全隔离环境中的完整计算机系统. 虚拟系统通过生成现有操作系统的全新虚拟镜像,它具有真实windows系统完全 ...
- 使用Node.js时如何引入jQuery
使用Node.js时如何引入jQuery 首先安装jQuery依赖 npm install jquery 然后安装jsdom npm install jsdom 引入jQuery 新版正确的依赖方式 ...
- Clickhouse单机部署以及从mysql增量同步数据
背景: 随着数据量的上升,OLAP一直是被讨论的话题,虽然druid,kylin能够解决OLAP问题,但是druid,kylin也是需要和hadoop全家桶一起用的,异常的笨重,再说我也搞不定,那只能 ...
- Logstash:处理多个input
Logstash:处理多个input Logstash的整个pipleline分为三个部分: input插件:提取数据. 这可以来自日志文件,TCP或UDP侦听器,若干协议特定插件(如syslog或I ...
- php 5.5 编译安装
链接:https://pan.baidu.com/s/1Iy5kdugWqmvtsrYG0WYAdA 提取码:knk9 上面的链接 php5.5.8 编译安装的包 ./configure --pre ...
- C# in 参数修饰符
in 修饰符记录: 新版C# 新增加的 in 修饰符:保证发送到方法当中的数据不被更改(值类型),当in 修饰符用于引用类型时,可以改变变量的内容,单不能更改变量本身. 个人理解:in 修饰符传递的数 ...
- Laravel向表里插入字段
执行: php artisan make:migration add_字段_to_表名_table --table=表名 此时在database/migrations文件夹下会生成一个相应文件,更改如 ...
- python3装饰器
由于函数也是一个对象,而且函数对象可以被赋值给变量,所以,通过变量也能调用该函数. >>> def now(): ... print('2015-3-25') ... >> ...
- NBIOT实现UDP协议的发送和接收(包含软件升级)
源码下载: nbiot_module程序(java netbean) -> 提取码 UdpServer程序(C# vs2010) -> 提取码 QQ:505645074 前提条件:开NB卡 ...