Skip to content

A mysql client in C/C++, orm database structure for c++, just like mybatis for java.

License

Notifications You must be signed in to change notification settings

garinyang/cppbatis

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

31 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MYSQL数据库客户端框架 CppBatis

[简介]

  • A orm database structure for mysql in c++, just like mybatis for java. MYSQL数据库客户端orm框架,思路参考的是高级语言中的orm思想,比如:python中的archery,java中的mybatis/plus. 应该算是所有通用实现里,代码最为简洁的一版;(该项目构建与MacOS环境,在linux环境下,cmake可能是否做些许调整;)

[开发目的]

  • C++查询mysql数据库中的行记录,不需要再关心field有多少个,是第几列,查询结果是一个二维数组,通过数组索引便利。
  • 只需定义个结构体对象,查询结果被封装在一个struct对象中,访问数据库列的值,转变为访问对象中的成员,非常方便,极大提升了C++数据库开发效率;

使用方式非常简单,如下:(连接池甚至可以不用)

  // 获取连接池对象
  auto pool = SingletonBase<ConnectPool>::ObtainInstance();
  
  // 获取mysql连接对象
  auto conn = pool.GetConnection();
  
  // 创建一个ps对象
  auto ps = std::make_unique<PrepareStatement>(conn);
  
  // 拼装 sql
  std::stringstream ss;
  ss << "SELECT * FROM ";
  ss << " user ";
  ss << " where age in (?, ?)";
  std::cout << "sql: [" << ss.str() << "]" <<std::endl;
  
  // 验证 sql
  ps->Prepare(ss.str());
  
  // 设置 where 条件 & 绑定
  int32_t limit_age = 1998;
  ps->SetInt32(0, limit_age);
  int64_t age1 = 2120202022;
  ps->SetInt64(1, age1);
  
  // 绑定参数
  ps->BindParam();
  // 根据 "结果集元信息" 申请绑定结果集空间;
  auto meta = ps->ObtainMetaDataWithResBound();

  // 执行对应的 查询 user 表
  std::vector<User> users;
  ps->Execute(users, meta);

  // 查询结果处理(打印)
  for (const auto user : users) {
    printf("#1# %d, %s, %s, %lld, %s ##\n", user.id, user.name.data(), user.email.data(), user.age, user.ttt.data());
  }

[使用说明]

  • 目前支持单表查询,每个 struct 映射 一张表,将所有行记录映射为一个个struct对象; (注意:struct字段名 必须与 表中 field名称一样!!!!

[编译]

  • cd cppbatis && mkdir build
  • cd build && cmake ..
  • make

生成

  • **libcppbatis.a // 数据库框架静态库 **
  • cppbatis_test // 测试程序

注意:测试用例,需要构建对应的库,表及字段(同struct_data中保持一致)!!!

[实现说明] img.png

  1. 基于 mysql prepare-statement statement C接口封装,支持简单的连接管理; (MySQL Connector/C 8.0)
  2. 开源依赖项:

[计划]

  • 第一步:[已完成] 基础preparestatement C接口封装一个简单的msyql连接客户端,支持简单的 "更新","查询";
  • 第二步:[已完成] 结合模板,改造"更新"&"查询"功能,实现"通用"的数据结构查询&更新功能;
  • 第三步:[待完成] 支持事务,联合查询,超时重连等;

[技术交流]

➕关注 公众号


作者: garin.yang 联系方式: garin.yang@outlook.com

About

A mysql client in C/C++, orm database structure for c++, just like mybatis for java.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published