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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: 本文以MySQL数据库为例,其他数据类似。 官方文档和下载 ODB官方首页    官方开发者说明书(开发教程) 安装下载首页(下载与安装教程Windows/Linux) Windows安装步骤(都是英文版,流程虽然详细,但是却略显麻烦,主要是因为ODB的机制造成的) ODB的使用原理 下...

本文以MySQL数据库为例,其他数据类似。

官方文档和下载

ODB官方首页    官方开发者说明书(开发教程)

安装下载首页(下载与安装教程Windows/Linux)

Windows安装步骤(都是英文版,流程虽然详细,但是却略显麻烦,主要是因为ODB的机制造成的)

ODB的使用原理

下面介绍ODB的使用原理来说明为什么会有这么多步骤:

ODB的架构和流程

(1)你自己定义一个C++的Person类.h/.cpp
(2)用安装的ODB Compiler编译Person.h得到新的

必选:

MySQL官方C开发库 

只用这个即可同时开发C++程序

作用:这个是MySQL官方提供的用于C开发程序读写MySQL提供头文件和动态链接库文件以及静态链接库文件,跟ODB没有任何关系。

这个不需要编译,提供现成的头文件和库文件。可以用C直接读写MySQL数据库。

官方下载地址(全部都有自己选): libmysqlclient

百度云下载仅提供:【mysql-connector-c-6.1.6-win32.zip】或者【mysql-connector-c-6.1.6-winx64.zip

MySQL官方C++开发库

不建议用:

后来发现/cpp里面下载的压缩文件中并没有【mysql_version.h】和【mysql_time.h】而是在/c的C版本包里有。所以下载了上面/c网址下的包。下载:mysql-connector-c++-noinstall-1.1.6-win32.zip 或者 mysql-connector-c++-noinstall-1.1.6-win64.zip

下载并使用ODB编译器

官方下载地址   百度云下载:odb-2.4.0-i686-windows.zip

主要功能:将自定义ODB结构编译生成标准的.hxx头文件和标准的.cxx源文件。

这个是个bin/odb.exe可执行文件,免安装。要想使用这个EXE只需要打开CMD终端,将目录切换到此目录即可执行:

上图表示odb已经可以使用。

下载并编译LIBODBlibodb-2.4.0.zip

主要作用:官方名称叫一般运行时库Common Runtime Library (libodb),odb的主要功能接口都在这个库里面提供。这里面有源代码和VS工程,编译完生成的库文件即可投入使用。

 

下载并编译数据库运行时库LIBODB-<DATABASE>

官方下载地址  libodb-mssql-2.4.0.zip、libodb-oracle-2.4.0.zip、libodb-mysql-2.4.0.zip

百度云下载:libodb-mssql-2.4.0.ziplibodb-oracle-2.4.0.ziplibodb-mysql-2.4.0.zip

主要作用:将第三方数据库接口封装成统一接口给libodb,从而实现跨数据库访问。这些运行时库用VS Building之后会生成lib和dll文件

libodb-mysql在编译的时候需要两个东西(参考INSTALL文件):

(1)libodb-2.4.0中编译生成的头文件和连接库

(2)MySQL的客户端包,也就是【mysql-connector-c-6.1.6-win32.zip】里面的头文件和连接库

添加方法参考:http://blog.csdn.net/calmreason/article/details/6989390

直接编译会因为(1)(2)你没有提供而报错:

将libodb的/lib和/odb目录拷贝到libodb-mysql的工程中覆盖

重新编译提示缺少mysql-connector-c头文件:

将mysql-connector-c-2.4.0中的include和lib目录拷贝到odb-mysql-2.4.0的工程中覆盖

重新设置工程属性,编译,编译成功:

Debug生成lib【odb-mysql-d.lib】和dll【odb-mysql-d-2.4-vc10.dll】文件

Release生成lib【odb-mysql-d.lib】和dll【odb-mysql-d-2.4-vc10.dll】文件

编译运行Hello World

官方下载地址   百度云下载:odb-examples-2.4.0.zip

选择examples版本(以MySQL为例):


将【hello-mysql-vc10】project设置为启动项目,直接编译会报错:error MSB6006: "cmd.exe" exited with code 9009.

这是odb环境变量没有设置成功的问题,需要将odb.exe路径设置到系统path变量中(最好重启生效)

之后会提示缺少一些头文件:主要是libodb的头文件、libodb-mysql的头文件

其实是需要:LIBODB(odb-d.lib)、LIBODB-<MYSQL>(odb-mysql-d.lib).(LIBMYSQLCLIENT(mysql-connector-c-6.1.6-win32)这个已经被编译到odblib-mysql中了,所以不需要了)。

头文件自己加,库文件需要什么工程里已经为你写好了:

由于刚才在编译libodb-mysql的时候已经将libodb和mysql-connector-c的资源添加过了。

所以现在只需要将libodb-mysql中的:include、odb、lib这三个目录靠过来并在example(或者你自己的工程)工程属性中添加引用即可。

 

目前项目中的【person.hxx】文件是一个odb模板文件,还不能直接被VS编译使用,项目中的【person-odb.hxx】、【person-odb.cxx】、【person-odb.ixx】也只是空引用,打不开,因为这些文件还不存在,需要odb编译器编译之后生成新的.h文件和.cpp文件才可以被CPP项目使用

将【person.hxx】拷贝到odb的bin目录下,cmd执行:odb -d mysql --generate-query --generate-schema person.hxx

执行完生成【person-odb.hxx】、【person-odb.cxx】、【person-odb.ixx】、【person.sql】这四个文件:

将这四个文件拷贝到本项目【person.hxx】文件同级目录下

 

创建数据库表

用【person.sql】创建数据库表。

可以成功编译:

生成的文件driver.exe在目录:【F:\编程开发\C++\ODB\odb-examples-2.4.0\odb-examples-2.4.0\hello\Debug】下,为了运行exe,需要将运行时库文件

libmysql.dll、odb-d-2.4-vc10.dll、odb-mysql-d-2.4-vc10.dll拷贝到此目录。

执行Start Without Debugging:

2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)
请按任意键继续. . .

可以看出程序默认连接本机的MySQL服务,并且企图访问端口:10061。

其实这需要具体的设置:ip,port,usr,psw,默认情况下程序使用命令行获取这些信息,参考2.3 Compiling and Running,关于如何使用database的构造函数直接传递数据库访问信息参考:3.4 Database 

直接修改代码,在代码中写死连接数据库的信息:

原来的代码:

 

[cpp]  view plain  copy
 
  1. auto_ptr<database> db (create_database (argc, argv));  

修改访问数据库的代码:

 

 

[cpp]  view plain  copy
 
  1. auto_ptr<odb::database> db (  
  2.     new odb::mysql::database (  
  3.     "root"     // database login name  
  4.     ,"123456" // database password  
  5.     ,"collect" // database name  
  6.     ,"localhost"  
  7.     ,13306  
  8.     ));  

编译运行:

 



这个例子可以跑起来其实是需要odb的所有步骤的,其他例子均可仿照这个例子的做法,自己创建的项目引用odb也是如此!奔跑吧,小怪兽!!

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
8天前
|
API C++ Windows
Visual C++运行库、.NET Framework和DirectX运行库的作用及常见问题解决方案,涵盖MSVCP140.dll丢失、0xc000007b错误等典型故障的修复方法
本文介绍Visual C++运行库、.NET Framework和DirectX运行库的作用及常见问题解决方案,涵盖MSVCP140.dll丢失、0xc000007b错误等典型故障的修复方法,提供官方下载链接与系统修复工具使用指南。
183 2
|
11天前
|
Ubuntu API C++
C++标准库、Windows API及Ubuntu API的综合应用
总之,C++标准库、Windows API和Ubuntu API的综合应用是一项挑战性较大的任务,需要开发者具备跨平台编程的深入知识和丰富经验。通过合理的架构设计和有效的工具选择,可以在不同的操作系统平台上高效地开发和部署应用程序。
56 11
|
27天前
|
缓存 算法 程序员
C++STL底层原理:探秘标准模板库的内部机制
🌟蒋星熠Jaxonic带你深入STL底层:从容器内存管理到红黑树、哈希表,剖析迭代器、算法与分配器核心机制,揭秘C++标准库的高效设计哲学与性能优化实践。
C++STL底层原理:探秘标准模板库的内部机制
|
15天前
|
IDE 编译器 开发工具
msvcp100.dll,msvcp120.dll,msvcp140.dll,Microsoft Visual C++ 2015 Redistributable,Visual C++ 运行库安装
MSVC是Windows下C/C++开发核心工具,集成编译器、链接器与调试器,配合Visual Studio使用。其运行时库(如msvcp140.dll)为程序提供基础函数支持,常因缺失导致软件无法运行。通过安装对应版本的Microsoft Visual C++ Redistributable可解决此类问题,广泛应用于桌面软件、游戏及系统级开发。
152 2
|
1月前
|
并行计算 C++ Windows
|
6月前
|
存储 算法 C++
Windows共享文件:探秘C++实现的B树索引算法奇境
在数字化时代,Windows共享文件的高效管理至关重要。B树算法以其自平衡多路搜索特性,在文件索引与存储优化中表现出色。本文探讨B树在Windows共享文件中的应用,通过C++实现具体代码,展示其构建文件索引、优化数据存储的能力,提升文件检索效率。B树通过减少磁盘I/O操作,确保查询高效,为企业和个人提供流畅的文件共享体验。
|
4月前
|
机器学习/深度学习 存储 算法
基于 C++ 布隆过滤器算法的局域网上网行为控制:URL 访问过滤的高效实现研究
本文探讨了一种基于布隆过滤器的局域网上网行为控制方法,旨在解决传统黑白名单机制在处理海量URL数据时存储与查询效率低的问题。通过C++实现URL访问过滤功能,实验表明该方法可将内存占用降至传统方案的八分之一,查询速度提升约40%,假阳性率可控。研究为优化企业网络管理提供了新思路,并提出结合机器学习、改进哈希函数及分布式协同等未来优化方向。
111 0
|
6月前
|
SQL 数据库连接 数据库
在C++的QT框架中实现SQLite数据库的连接与操作
以上就是在C++的QT框架中实现SQLite数据库的连接与操作的基本步骤。这些步骤包括创建数据库连接、执行SQL命令、处理查询结果和关闭数据库连接。在实际使用中,你可能需要根据具体的需求来修改这些代码。
356 14
|
9月前
|
JSON C++ 数据格式
C++20 高性能基础库--兰亭集库助力开发者构建高性能应用
这次分享的主题是《高性能基础库--兰亭集库助力开发者构建高性能应用》的实践经验。主要分为三个部分: 1. 业务背景 2. 雅兰亭库架构 3. 业务优化
242 9