扔掉sql语句,用 QxOrm 让你的数据库操作从来没有这么简单过!

2023-12-07 18:36

本文主要是介绍扔掉sql语句,用 QxOrm 让你的数据库操作从来没有这么简单过!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

ORM简介:

ORM 全称是 Object Relational Mapping(对象关系映射),是一种程序设计技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。从效果上说,它其实是创建了一个可在编程语言里使用的“虚拟对象数据库”。

面向对象是从软件工程基本原则(如耦合、聚合、封装)的基础上发展起来的,而关系数据库则是从数学理论发展而来的,两套理论存在显著的区别。为了解决这个不匹配的现象,对象关系映射技术应运而生。

简单理解,ORM 就是在数据库和对象之间作了一个映射:

数据库的表(table) –> 类(class)
字段(field)–> 对象的属性(attribute)

关于QxOrm

http://www.qxorm.com/qxorm_en/manual.html

这是QxOrm的官方手册,如果要使用QxOrm,需要重点阅读下。

QxOrm 是一个 C++ 库,旨在为 C++ 用户提供对象关系映射 (ORM) 功能。
QxOrm 由 Lionel Marty 开发,他自 2003 年以来一直担任软件开发工程师。

基于每个类的简单 C++ 设置函数(如 Java 中的 Hibernate XML 映射文件),QxOrm 库提供以下功能:

主页:http://www.qxorm.com/qxorm_en/home.html
下载:http://www.qxorm.com/qxorm_en/download.html
手册:http://www.qxorm.com/qxorm_en/manual.html
在线类文档:http://www.qxorm.com/doxygen/html/index.html
GitHub:https://github.com/QxOrm/QxOrm

其主要特性包括:
持久性:支持最常见的数据库,如 SQLite、MySQL、PostgreSQL、Oracle、MS SQL Server、MongoDB(具有 1-1、1-n、n-1 和 n-n 关系)。

序列化:JSON、二进制和 XML 格式。

反射(或内省):动态访问类定义、检索属性和调用类方法。

HTTP Web Server:独立的多线程 HTTP 1.1 web 服务器(支持 SSL/TLS、持久连接、cookie、会话、分块响应、URL 分发器/路由)。

JSON API:与 C++/Qt 以外的其他技术的互操作性(REST web 服务、QML 应用程序、脚本语言)。

默认情况下,QxOrm 库只依赖 QtCore 和 QtSql 模块。如果启用 QxOrm HTTP web server 特性,那么还将依赖于 QtNetwork 模块。除此之外,有些特性还需要依赖 boost(默认禁用)

QxOrm 库是多平台的,可以安装在所有环境中:Windows、Linux、Mac OS X、Android、iOS、Windows Phone、Raspberry Pi 等…

依赖

Qt的 GUI(QtGui,可选)、网络(QtNetwork,可选)、XML(QtXml,可选)、数据库(QtSql)…
QxOrm 兼容许多 Qt 对象:QObject、QString、QDate、QTime、QDateTime、QList、QHash、QSharedPointer、QScopedPointer…

注意:默认情况下,QxOrm 库仅依赖于 QtCore 和 QtSql 二进制文件。 可以在 QxOrm.pri(或 QxOrm.cmake)配置文件中启用额外的功能:某些功能可以向 QxOrm 库添加依赖项。

构建和使用

1、下载

http://www.qxorm.com/qxorm_en/download.html

上面的链接下载源码包,或者下面的链接下载我编译好的windows版本的64位和32位的dll和lib和头文件。

https://download.csdn.net/download/u012534831/88606094

2、构建

使用cmake-gui.exe 或者 qtcreator 工具或者visual studiio 都可以,源码包下提供了 cmakelist.txt文件和pro文件和sln文件,直接可以构建,无需修改cmake。

在这里插入图片描述

如果使用cmake构建,构建时这些参数可选,默认情况下它们都是禁用的:

  • _QX_ENABLE_BOOST:添加一个依赖项来提升头文件(*.hpp),支持一些类,如:boost::shared_ptr、boost::optional、boost::container等…;
  • _QX_ENABLE_BOOST_SERIALIZATION:启用boost::serialization engine。此选项需要构建boost::serialization二进制文件,并向QxOrm库添加依赖项;
  • _QX_ENABLE_QT_GUI:支持QtGui类型的序列化:QBrush、QColor、QFont、QImage、QMatrix、QPicture、QPixmap、QRegion。此选项将依赖项添加到 QxOrm 库 (QtGui) ;
  • _QX_ENABLE_QT_NETWORK:启用 QxService 模块以通过网络(客户端/服务器应用程序)传输持久数据层。此选项将依赖项添加到 QxOrm 库 (QtNetwork) ;
  • _QX_NO_PRECOMPILED_HEADER : 禁用预编译头文件(用于减少项目的编译时间):最新版本的 MinGW 需要此选项(由于已知的编译器错误),对于所有其他编译器,建议使用预编译头文件 ;
  • _QX_NO_RTTI:在没有RTTI C++类型信息的情况下构建QxOrm库(以及所有依赖于QxOrm的项目) ;
  • _QX_STATIC_BUILD:在静态模式下构建 QxOrm 库(但建议将 QxOrm 构建为共享库)。
  • _QX_UNITY_BUILD:使用 Unity 构建概念减少 QxOrm 库编译时间:只需编译一个全.cpp源文件。建议使用 CMake 启用此选项(因为不支持本机预编译标头);
  • _QX_ENABLE_MONGODB:支持MongoDB数据库,QxOrm库成为ODM(对象文档映射器)。

我构建的时候只打开了 _QX_UNITY_BUILD 一个选项,也没有用boost。

3、使用

这是构建后的源码目录:
在这里插入图片描述

构建好后,像下面这样,将构建的库放到测试程序下。
在这里插入图片描述

编写pro文件:

QT  += core gui sqlgreaterThan(QT_MAJOR_VERSION, 4): QT += widgetsCONFIG += c++17HEADERS += \oemconfig.h\mainwindow.hSOURCES += \main.cpp \oemconfig.cpp\mainwindow.cppFORMS += \mainwindow.uiINCLUDEPATH += $$PWD/include/
LIBS += -L"$$PWD/lib"
LIBS += -l"QxOrm"

我们新建model类进行测试:

#ifndef OemConfigModel_H
#define OemConfigModel_H#include <QString>
#include <QxOrm.h>class  OemConfigModel
{
public:OemConfigModel() : id(0) { }virtual ~OemConfigModel() { }long id;QString name;int age;
};
QX_REGISTER_HPP_EXPORT_DLL(OemConfigModel, qx::trait::no_base_class_defined, 0)#endif // OemConfigModel_H

此处需要注意的是,官方文档和网上的文章都是让使用 QX_REGISTER_HPP 来进行对象注册,经过测试发现是不可行的,无法通过编译。查看issue发现有人使用 QX_REGISTER_HPP_EXPORT_DLL 进行注册,经过验证后是可以的。下面的cpp文件同理,需要使用 QX_REGISTER_CPP_EXPORT_DLL 而不是 QX_REGISTER_CPP。
~~在这里插入图片描述~~

#include "oemconfig.h"QX_REGISTER_CPP_EXPORT_DLL(OemConfigModel)namespace qx
{
template <> void register_class(QxClass<OemConfigModel>& t)
{t.setName("t_OemConfigModel");// 注册 User::id <=> 数据库中的主键t.id(&OemConfigModel::id, "id");// 注册 User::name 属性,使用的 key 是 name,version 是 1。t.data(&OemConfigModel::name, "name");// 注册 User::age 属性,使用的 key 是 age。t.data(&OemConfigModel::age, "age");
}
}
#include "mainwindow.h"
#include <QApplication>
#include "oemconfig.h"int main(int argc, char* argv[])
{QApplication a(argc, argv);MainWindow w;w.show();QFile::remove("./Users.db");// 初始化参数,用于和数据库交互qx::QxSqlDatabase::getSingleton()->setDriverName("QSQLITE");qx::QxSqlDatabase::getSingleton()->setDatabaseName("./Users.db");qx::QxSqlDatabase::getSingleton()->setHostName("localhost");qx::QxSqlDatabase::getSingleton()->setUserName("root");qx::QxSqlDatabase::getSingleton()->setPassword("");// 在数据库中创建 User 表QSqlError daoError;daoError = qx::dao::create_table<OemConfigModel>();
//    qDebug() << daoError.text();// 创建 3 个用户// 可以使用 std 和 Qt 智能指针:std::shared_ptr、QSharedPointer 等...typedef  QSharedPointer<OemConfigModel> UserPtr;UserPtr u1;u1.reset(new OemConfigModel());u1->id = 1;u1->name = "Jack Ma";u1->age = 30;UserPtr u2;u2.reset(new OemConfigModel());u2->id = 2;u2->name = "Pony";u2->age = 25;UserPtr u3;u3.reset(new OemConfigModel());u3->id = 3;u3->name = "Waleon";u3->age = 18;// 将所有用户插入容器中// 可以使用 std、boost、Qt 和 qx::QxCollection<Key,Value> 中的许多容器typedef QVector<UserPtr> VectorUser;VectorUser users;users.push_back(u1);users.push_back(u2);users.push_back(u3);// 将容器中的所有用户插入到数据库中// p1、p2、p3 的 id 属性会自动更新daoError = qx::dao::insert(users);qDebug() << daoError.text();// 修改第二个用户的信息,并更新到数据库中u2->age = 38;daoError = qx::dao::update(u2);// 从数据库中删除第一个用户u1.reset(new OemConfigModel());u1->name = "Jack Ma";daoError = qx::dao::delete_by_id(u1);// 计算用户的数量long userCount = qx::dao::count<OemConfigModel>();qDebug() << "User Count: " << userCount;// 将 id 为 3 的用户取出,并传给一个新变量UserPtr userTmp;userTmp.reset(new OemConfigModel());userTmp->name = "qht";daoError = qx::dao::fetch_by_id(userTmp);qDebug() << "User Tmp: " << userTmp->id << userTmp->name << userTmp->age;return a.exec();
}

运行程序,会打印一系列sql执行的输出信息,QxOrm 不会隐藏 SQL 查询(默认情况下,所有的语句都会显示),所以在控制台中可以看到执行过程,如果想要关闭,可以使用官方建议的下面的方法,但是我测试了没有用,因此我用QT的自定义日志拦截器对 包含 QxOrm的日志进行了过滤。

 qx::QxSqlDatabase::getSingleton()->setFormatSqlQueryBeforeLogging(false);qx::QxSqlDatabase::getSingleton()->setVerifyOffsetRelation(false);qx::QxSqlDatabase::getSingleton()->setTraceSqlQuery(false);qx::QxSqlDatabase::getSingleton()->setTraceSqlBoundValuesOnError(false);qx::QxSqlDatabase::getSingleton()->setTraceSqlRecord(false);qx::QxSqlDatabase::getSingleton()->setTraceSqlBoundValues(false);qx::QxSqlDatabase::getSingleton()->setTraceSqlBoundValuesOnError(false);

You can install your own message handler (using qInstallMessageHandler), and filter all messages which start with [QxOrm] :
https://doc.qt.io/qt-5/qtglobal.html#qInstallMessageHandler

好了,今天这篇文章介绍了QxOrm的使用,后面还会介绍比如 非ID主键、复合主键等其他使用方法。

在这里插入图片描述
关注公众号 QTShared,带你探索更多QT相关知识。

这篇关于扔掉sql语句,用 QxOrm 让你的数据库操作从来没有这么简单过!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/466939

相关文章

RedHat运维-Linux文本操作基础-AWK进阶

你不用整理,跟着敲一遍,有个印象,然后把它保存到本地,以后要用再去看,如果有了新东西,你自个再添加。这是我参考牛客上的shell编程专项题,只不过换成了问答的方式而已。不用背,就算是我自己亲自敲,我现在好多也记不住。 1. 输出nowcoder.txt文件第5行的内容 2. 输出nowcoder.txt文件第6行的内容 3. 输出nowcoder.txt文件第7行的内容 4. 输出nowcode

一份LLM资源清单围观技术大佬的日常;手把手教你在美国搭建「百万卡」AI数据中心;为啥大模型做不好简单的数学计算? | ShowMeAI日报

👀日报&周刊合集 | 🎡ShowMeAI官网 | 🧡 点赞关注评论拜托啦! 1. 为啥大模型做不好简单的数学计算?从大模型高考数学成绩不及格说起 司南评测体系 OpenCompass 选取 7 个大模型 (6 个开源模型+ GPT-4o),组织参与了 2024 年高考「新课标I卷」的语文、数学、英语考试,然后由经验丰富的判卷老师评判得分。 结果如上图所

mysql索引四(组合索引)

单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引;组合索引,即一个索引包含多个列。 因为有事,下面内容全部转自:https://www.cnblogs.com/farmer-cabbage/p/5793589.html 为了形象地对比单列索引和组合索引,为表添加多个字段:    CREATE TABLE mytable( ID INT NOT NULL, use

mysql索引三(全文索引)

前面分别介绍了mysql索引一(普通索引)、mysql索引二(唯一索引)。 本文学习mysql全文索引。 全文索引(也称全文检索)是目前搜索引擎使用的一种关键技术。它能够利用【分词技术】等多种算法智能分析出文本文字中关键词的频率和重要性,然后按照一定的算法规则智能地筛选出我们想要的搜索结果。 在MySql中,创建全文索引相对比较简单。例如:我们有一个文章表(article),其中有主键ID(

mysql索引二(唯一索引)

前文中介绍了MySQL中普通索引用法,和没有索引的区别。mysql索引一(普通索引) 下面学习一下唯一索引。 创建唯一索引的目的不是为了提高访问速度,而只是为了避免数据出现重复。唯一索引可以有多个但索引列的值必须唯一,索引列的值允许有空值。如果能确定某个数据列将只包含彼此各不相同的值,在为这个数据列创建索引的时候就应该使用关键字UNIQUE,把它定义为一个唯一索引。 添加数据库唯一索引的几种

mysql索引一(普通索引)

mysql的索引分为两大类,聚簇索引、非聚簇索引。聚簇索引是按照数据存放的物理位置为顺序的,而非聚簇索引则不同。聚簇索引能够提高多行检索的速度、非聚簇索引则对单行检索的速度很快。         在这两大类的索引类型下,还可以降索引分为4个小类型:         1,普通索引:最基本的索引,没有任何限制,是我们经常使用到的索引。         2,唯一索引:与普通索引

关于如何更好管理好数据库的一点思考

本文尝试从数据库设计理论、ER图简介、性能优化、避免过度设计及权限管理方面进行思考阐述。 一、数据库范式 以下通过详细的示例说明数据库范式的概念,将逐步规范化一个例子,逐级说明每个范式的要求和变换过程。 示例:学生课程登记系统 初始表格如下: 学生ID学生姓名课程ID课程名称教师教师办公室1张三101数学王老师101室2李四102英语李老师102室3王五101数学王老师101室4赵六103物理陈

数据库期末复习知识点

A卷 1. 选择题(30') 2. 判断范式(10') 判断到第三范式 3. 程序填空(20') 4. 分析填空(15') 5. 写SQL(25') 5'一题 恶性 B卷 1. 单选(30') 2. 填空 (20') 3. 程序填空(20') 4. 写SQL(30') 知识点 第一章 数据库管理系统(DBMS)  主要功能 数据定义功能 (DDL, 数据定义语

【服务器运维】MySQL数据存储至数据盘

查看磁盘及分区 [root@MySQL tmp]# fdisk -lDisk /dev/sda: 21.5 GB, 21474836480 bytes255 heads, 63 sectors/track, 2610 cylindersUnits = cylinders of 16065 * 512 = 8225280 bytesSector size (logical/physical)

Eureka高可用注册中心registered-replicas没有分布式注册中心

自己在学习过程中发现,如果Eureka挂掉了,其他的Client就跑不起来了,那既然是商业项目,还是要处理好这个问题,所以决定用《Spring Cloud微服务实战》(PDF版在全栈技术交流群中自行获取)中说的“高可用注册中心”。 一开始我yml的配置是这样的 server:port: 8761eureka:instance:hostname: 127.0.0.1client:fetch-r