UE4连接MySQL数据库插件开发之编写查询数据代码

本文介绍了如何在UE4中开发一个蓝图插件,用于连接MySQL数据库并执行查询操作。详细步骤包括:创建SqlBlueprintFunctionLibrary类,声明结构体和函数,处理SQL语句,封装查询结果,解决编译警告,以及在蓝图中使用查询节点进行多条件联合查询。文章还展示了查询功能的实现过程和示例。
摘要由CSDN通过智能技术生成

本篇我们介绍如何向SqlBlueprintFunctionLibrary类中添加查询记录的代码。

 


1、首先介绍下编写思路,蓝图节点与C++底层代码设计如下所示。


蓝图节点输入参数有4个,输出参数有2个。我们将传入的参数进行处理后,执行SQL语句。从数据库查询到数据,由底层处理为结构体数组,暴露给蓝图。 


2、首先打开以前创建的项目,找到并且打开SqlBlueprintFunctionLibrary类的声明(.h)和实现(.cpp)文件。


 3、在SqlBlueprintFunctionLibrary.h文件中,类声明(UCLASS)前添加如下所示代码。


/** 一行所含数据 */
USTRUCT(BlueprintType)
struct FQueryResultRow
{
	GENERATED_BODY()
		/** 一行的数据 */
		UPROPERTY(BlueprintReadWrite, Category = "Reult Row Value")
		TArray<FString> RowValue;
};
/** 所有行所数据 */
USTRUCT(BlueprintType)
struct FQueryResultRows
{
	GENERATED_BODY()
		/** 所有行数据 */
		UPROPERTY(BlueprintReadWrite, Category = "Reult Rows Value")
		TArray<FQueryResultRow> RowsValue;
};

上述所声明的结构体用来存储数据。BlueprintType表名该结构体是蓝图类型的,允许蓝图进行操作,里面的属性也是一样。FQueryResultRow存储的是一行的数据,FQueryResultRows存储的是所有行的数据。

<
1、本课程是一个干货课程,主要讲解如何封装服务器底层,使用Tcp/ip长连接,IDE使用vs2019 c++开发以及使用c++11的一些标准,跨平台windows和linux,服务器性能高效,单服务器压力测试上万无压力,服务器框架是经历过上线产品的验证,框架简单明了,不熟悉底层封装的人,半个小时就能完全掌握服务器框架上手写业务逻辑。2、本课程是一个底层服务器框架教程,主要是教会学员在windows或linux下如何封装一个高效的,避免踩坑的商业级框架,服务器底层使用初始化即开辟内存的技术,使用内存池,服务器运行期间内存不会溢出,非常稳定,同时服务器使用自定义哈希hashContainer,在处理新的连接,新的数据,新的封包,以及解包,发包,粘包的过程,哈希容器性能非常高效,增、删、查、改永远不会随着连接人数的上升而降低性能,增、删、查、改的复杂度永远都是恒定的O(1)。3、服务器底层封装没有使用任何第三方网络库以及任何第三方插件,自由度非常的高,出了任何BUG,你都有办法去修改,查找问题也非常方便,在windows下使用iocp,linux下使用epoll.4、讲解c++纯客户端,主要用于服务器之间通信,也就是说你想搭建多层结构的服务器,服务器与服务器之间使用socket通信。还可以使用c++客户端做压力测试,开辟多线程连接服务器,教程提供了压力测试,学员可以自己做压力测试服务器性能。5、赠送ue4和unity3d通信底层框架以及多人交互demo,登录,注册,玩家离开,同步主要是教会学员服务器与客户端如何交互。6、赠送c++连接mysql数据库框架demo,登录,注册,玩家离开数据持久化.7、服务器教程使用自定义通信协议,同时也支持protobuf,选择权在开发者自己手里,想用什么协议都可以,自由度高。8、服务器教程使用手动敲代码逐句讲解的方式开展教学课程。非喜勿喷,谢谢大家。9、服务器教程提供源码,大家可以在平台提供的地址下载或者联系我,服务器使用c++11部分标准,std::thread,条件变量,线程锁,智能指针等,需要学员具备一定c++知识,购买前请慎重考虑。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值