如何使用的Ue4自带的SQLiteSupport

在UE4.6版本加入的模块。可以让开发者使用SQLite数据库。SQlite是个轻量型的本地数据库。

我下面就来介绍一下如何使用这个模块。

第一步:下载SQLite源代码以及SQLite GUI管理工具SQLite Expert。

进入http://www.sqlite.org/,点击

DownLoad,选择源代码下载。

SQLite Expert可以去http://www.sqliteexpert.com/下载,个人版是完全免费,这里我推荐用破解的专业版,同时本人不太喜欢新版本。

第二步:编译对应平台的LIB文件

进入\Engine\Source\ThirdParty\sqlite,并且新建文件夹命名为sqlite,将源代码中的文件解压至新建的文件夹。之后返回上级目录,运行VS工程文件。将Debug、Release以及对应的win32、x64都编译一遍,虽然只需要对应平台,但是你以后肯定会打包的,所以为了避免以后找不到这个问题,在这里就全编译了。

第三步:编译引擎

这步我也不确定,官方说明文件中有说需要编译,但是我因为已经编译过了,所以也不太确定。

第四步:在工程文件中加入SQLiteSupport模块

PublicDependencyModuleNames.AddRange(new string[] { "Core", "CoreUObject", "Engine", "InputCore" , "SQLiteSupport" });

最后在需要使用SQLite的地方包含头文件

#include "Runtime/SQLiteSupport/Public/SQLiteDatabaseConnection.h"

之后就可以使用SQLite了。

下面是一段我测试用的代码,具体怎么用,麻烦各位去看源代码,一共也没几个函数,如果用过SQLite SDK能很快上手。

  FSQLiteDatabase Database;
    Database.Open (TEXT("D:\\UnrealProject\\Sqlite\\Content\\database.db"), nullptr, nullptr);
    //run query where no results are returned
    Database.Execute (*(FString::Printf (TEXT ("insert into test (id,name) values (1,123)"), *(FDateTime::Now ().ToString ()), *(FApp::GetSessionId ().ToString ()))));
    Database.Close();

这个是AnswerHub的案例代码,我发现第一句话就错了,下面的仅供参考

//create and open the database

     FSQLiteDatabase Database();

     Database.Open("Path\\To\\File", nullptr, nullptr);

     //run query where no results are returned

     Database->Execute(*(FString::Printf(TEXT("Update GameSession set SessionTimeEnd= %s where SessionID = %s"), *(FDateTime::Now().ToString()), *(FApp::GetSessionId().ToString()))));

     //run query to fetch results from database

     FSQLiteResultSet* NameResults = NULL;

     if (Database.Execute(*(FString::Printf(TEXT("Select * from Players where SessionID = %s;"), *SessionID)),NameResults))

     {

         for (FSQLiteResultSet::TIterator NameIterator(NameResults); NameIterator; ++NameIterator)

         {

             //do something with the results here

         }

     }
时间: 2024-08-27 18:02:11

如何使用的Ue4自带的SQLiteSupport的相关文章

UE4开发神秘海域类游戏原型 初阶(二):动画资源的整合

前一篇已经确定神海类游戏原型的目标,首先要做的就是3C's(Character, Controls, Camera)的开发. UE4的3C's的程序部分开发主要也就是基于他的GamePlay Framework来进行的,只要在C++里开发完成,通过蓝图类继承,把参数暴露给蓝图就可以由策划和美术师来直接使用了.鉴于UE4自带的Learn Project的示例代码里还是有相当多参考示例的,一些基础内容这里就跳过不讲了,具体的功能实现会在面涉及需求时详细说明.官方的介绍在这里. https://doc

UE4高级功能--初探超大无缝地图的实现LevelStream

前言 好吧,这次总结的还是UE4,在这里要向CE3的朋友们道一声歉,因为本人水品有限,对于CE3的探索学习陷入了一个非常大的瓶颈,暂时抽不出一块儿大的单独的时间去解决,另外,自己也有一点小小的私念,就是期盼Cryteck官方能够推出新的版本,至少能完善一下现在的文档,所以只能暂时把CE3搁置下来,但是我并不会放弃CE3,CE3对我来说,绝对是个非常大的挑战,我不会轻易放弃他的. 好了回归正题,先来简单说一下写这篇文章的背景吧,这两天我试着看了一下UE4官方提供的实例"2014功能介绍"

UE4子弹特效

转自:http://blog.ch-wind.com/ue4-projectile-visual-effects/ 子弹使用抛体就可以实现了,但是要让其看起来更加真实,则可能需要加上一些粒子特效. 当前UE4版本4.8.1. 子弹的特效制作主要使用粒子系统进行实现,只有用于着弹效果的地方使用的是Decal Material.官方的这篇教程对于了解如何去制作一个粒子系统很有作用.原始教程地址:https://wiki.unrealengine.com/Projectile_Visual_Effec

[UE4]使用C++重写蓝图

先大量使用蓝图制作项目,后续再用C++把复杂的蓝图重写一遍,用C++代码按照蓝图依葫芦画瓢就可以了,很简单,但需要遵守一些原则: 一.创建一个C++类作为蓝图的父类(C++类继承蓝图一样的父类),在UE4中修改蓝图的父类. 二.C++类中的方法.成员变量与蓝图一一对应,并且方法和成员变量名称不能与蓝图的重复. 三.A蓝图不能直接使用B蓝图的变量,A蓝图把要公开的变量封装在函数内返回,并且只返回UE4自带的基础变量类型,不能返回自定义类型,以方便C++重写时返回C++中的成员变量. 四. 原文地址

Aery的UE4 C++游戏开发之旅(3)蓝图

目录 蓝图 蓝图命名规范 蓝图优化 暴露C++至蓝图 暴露C++类 暴露C++属性 暴露C++函数 暴露C++结构体/枚举 暴露C++接口 蓝图和C++的结合方案 使用继承重写蓝图 使用组合重写蓝图 方案比较 参考 蓝图 大家都知道,蓝图是UE4提供的极其容易上手的一种可视化脚本,更具体的就不说了. 纯靠蓝图搭建的UE4游戏是存在的,但是这类游戏往往优化很差(除非游戏玩法本身的性能需求不高).更合适的流程往往需要程序员编写C++代码创建一些蓝图可用元素,而设计师再通过蓝图快速搭建游戏. 蓝图命名

[UE4]使用name slot制作带背景的容器

name slot相当于asp.net模板中的content模板. 可以往“Name Slot”里面拖放控件,如果没有“Name Slot”就不能给“BgPanel”拖放任何控件 原文地址:https://www.cnblogs.com/timy/p/9143204.html

[UE4]Scroll Box带滚动条的容器

一.黑边,当可以往下滚动的时候,下边会出现黑边.当可以往上滚动的时候,上边也会出现黑边.   Scroll Box.Style.Style:也可以自定义上下左右黑边的样式: 二.Scroll Box.Orientation:Scroll Box默认是纵向排列子控件,也可以修改成横向排列.但没法横向和纵向都出现滚动条. 三.Scroll Box.Style.Bar Style:自定义滚动条的样式.   四. Scroll Box.Scroll Bar visibility:滚动条是否可见 五.Sc

UE4常见的Actor类型

UE4引擎里常见的Actor类型: 类型 图标 描述 网格物体 & 几何体Actor类型 StaticMeshActor 静态网格物体Actor 是一种简单的Actor类型,用于在场景中显示一个网格物体.尽管其名称暗示该Actor是静态的或者是不能移动的,但是此名称中的 静态 是指这种网格物体类型使用的是StaticMesh(静态网格物体).由于这些网格物体的几何体不能改变,所以这些网格物体是静态的.但是,实际上在游戏运行过程中可以通过其他方式来移动及修改Actor.这些Actor一般用作为 世

张瀚荣:如何用UE4制作3D动作游戏

转自:http://www.gamelook.com.cn/2015/06/218267 GameLook报道/ 6月5日,2015年第三期GameLook开放日?虚幻引擎专场活动在上海正式举行,此次活动由Epic Games与GameLook联合主办. 动作游戏凭借爽快的打击感和强烈的操作感一直受到玩家的喜爱,但一些高品质的3D动作游戏设计其实颇有难度,国内市场上常见的大多是横版2D游戏.本次活动上,Megafun的创始人张瀚荣来分享了利用UE4引擎制作3D横版动作游戏的心得. 张瀚荣从策划的