百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

「技术分享」Unity使用SQLite数据库存储本地数据

liuian 2024-12-07 14:59 36 浏览

前言

  • 单机游戏开发过程中,一款高效便捷的本地数据存储库一定是必不可少的。今天介绍unity结合SQLite数据库来完成本地数据的存储。

开发环境

  • 引擎:Unity 2018.4.16f1
  • 插件:sqlitekit

SQLite的优势

  • SQLite是一种嵌入式数据库,它的数据库就是一个文件。
  • 基于sqlitekit可实现跨平台本地数据存储,不用过多考虑跨平台问题
  • 基于sqlitekit可实现数据加密存储,能有效的提高本地数据的安全
  • 实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎

相关逻辑及关键代码

  • 创建db库文件:在编辑器模式下创建属于自己工程的db库文件,将其放入StreamingAssets文件夹下,便于后续开发以及打包对应平台后将库文件移植到对应平台的可读可写文件夹下。
     	  SQLiteDB sqLiteDb = new SQLiteDB();
        string filename = Application.streamingAssetsPath + "/gameSql.db";
        if (System.IO.File.Exists(filename))
        {
            System.IO.File.Delete(filename);
        }
        sqLiteDb.Open(filename);
  • 创建数据表:根据需求创建一张用于存储数据的表单,创建成功后相应的数据就可通过增删改查来修改表内的数据内容了。
        //id INTEGER PRIMARY KEY设置自增Id,DataKey BIGINT, Data BLOB,Size INT表示 字段名称 字段类型,字段名称 字段类型,字段名称 字段类型
				string query_create = #34;{CREATE TABLE IF NOT EXISTS}{表名}(id INTEGER PRIMARY KEY, DataKey BIGINT, Data BLOB,Size INT);";
        SQLiteQuery query = new SQLiteQuery(sqLiteDb, password);

        query.Step();
        query.Release();
        query = new SQLiteQuery(sqLiteDb, queryCreate);
        query.Step();
        query.Release();
  • 数据表内插入数据:向已经创建好的表内插入一行新的数据
        string data = "需要存储的数据";
				long id
				string queryInsert = #34;INSERT INTO{tableName} (DataKey,Data) VALUES(?,?);";
        SQLiteQuery query = new SQLiteQuery(sqLiteDb, password);
        query.Step();
        query.Release();
        query = new SQLiteQuery(sqLiteDb, queryInsert);
        query.Bind(id);
        query.Bind(data);
        query.Step();
        query.Release();
        netData.OnRecycling();
  • 更新数据表内已有的数据:表内已有存储好的数据,对其数据进行更新修改
        long id = 存储数据的key值
				string data = "需要存储的数据";       
				string query_update = #34;UPDATE {表名} SET Data = ? WHERE DataKey = ?;";//
        SQLiteQuery query = new SQLiteQuery(sqLiteDb, password);
        query.Step();
        query.Release();
        query = new SQLiteQuery(sqLiteDb, query_update);
        query.Bind(data);
        query.Bind(id);
        query.Step();
        query.Release();
  • 查找数据表内的数据:查询数据表内的数据内容,未查询到数据时返回空数据
				string value = string.Empty;
				long id = 存储数据的key值
			  //若删除 WHERE DataKey = ?将查询整张表内的数据
				string query_select = #34;SELECT * FROM {表名} WHERE DataKey = ?;";
        SQLiteQuery query = new SQLiteQuery(sqLiteDb, password);
        query.Step();
        query.Release();
        query = new SQLiteQuery(sqLiteDb, query_select);
        query.Bind(id);
        if (query.Step())
        {
            value = query.GetBlob("Data");
        }
        query.Release();
  • 删除数据表内的数据:将数据表内的数据删除掉(删除有风险,谨防删库跑路事件发送)。
        long id = 存储数据的key值
				//若删除 WHERE DataKey = ?将删除整张表内的数据
				string query_delete = #34;DELETE FROM {表名} WHERE DataKey = ?;";
        SQLiteQuery query = new SQLiteQuery(sqLiteDb, password);
        query.Step();
        query.Release();
        query = new SQLiteQuery(sqLiteDb, query_delete);
        query.Bind(id);
        query.Step();
        query.Release();
  • 关闭数据数据库:退出程序时记得将数据库关闭释放
sqLiteDb.Close();
  • 打包后安卓和ios移动平台需要将db文件放入可读可写文件夹下
        string outFile =  string.Empty;
#if UNITY_ANDROID
        outFile = Application.persistentDataPath + "/gameSql.db";
#elif UNITY_IPHONE
        outFile = "file://" + Application.persistentDataPath + "/gameSql.db";
#endif
        string resPath = Application.streamingAssetsPath + "/gameSql.db";
        if (File.Exists(outFile)) File.Delete(outFile);
        UnityWebRequest request = UnityWebRequest.Get(resPath);
        request.timeout = 30;
        yield return request.SendWebRequest();
				System.IO.File.WriteAllBytes(outFile,request.downloadHandler.data);

结束语

  • 灵活运用sqlitekit能使自己的本地数据存储更加便利,后续会介绍sqlitekit和protobuf结合在Unity中的使用。

相关推荐

win10官网下载教程(windows官网下载win10)

步骤1首先打开360安全浏览器步骤2在搜索框中输入“微软官网”,点击“搜索”按钮步骤3点击进入微软官网步骤4下滑界面,在下方可以看到可以下载的系统,此处以windows10企业版下载为例,点击这个版本...

恢复帝app下载(恢复帝app官方)

微信删除好友一般是不能恢复的,有时候在网上会看到一些关于微信删除好友可以帮助恢复的黑客,大多数都是骗人的,因此,再着急恢复好友也需要理智、谨防上当受骗。1.电源:首先确认摄像头通电是否正常状态,指示灯...

系统之家下载安装(系统之家安装版)

是靠谱的。系统之家(HomeSystem)广义上包含了电脑系统安装和手机系统安装,在之前手机软件还不是很普及的时候一般特指电脑系统安装,可如今手机用户大量的出现,安卓系统可以说超过Windows系统...

win10正版系统官网原版纯净版老电脑

一,纯净版Win10系统是根据正版系统制作的,没有夹杂其它软件和驱动,和正版系统一样安装完后需要打各种驱动和根据安装常用软件。二,本质上纯净版Win10也是盗版系统,这是和正版系统最大的区别,而且可能...

十大最好用的浏览器(市面上最好用的浏览器)

1、谷歌chrone  谷歌美国Google公司开发的一款浏览器,谷歌浏览器的特点就是界面简洁,速度快不卡顿,内容全面,你想要找到内容上面都有,就是在安装插件的方面会比较麻烦,不过看在它那么好用的份...

ipad充不上电了怎么办(ipad充不上电怎么办但显示在充电)

 原因和解决办法: 1、ipad充不进去电很可能是充电线的原因,假如大家在给ipad充电的时候以前经常有过接触不良的情况,那么,你就需要考虑更换充电线了。  2、第二,就是接口问题了,或者说是充电...

怎样取消开机启动项目(如何取消开机启动程序)

在Windows操作系统中,有一些程序或服务可能会在计算机启动时自动运行,这些程序或服务也被称为开机启动项。如果您希望在启动Windows时减少计算机运行的程序或服务数量,您可以关闭一些开机启...

纯净版win7完整版ghost下载(纯净版的win7)

1、去微软官方网站下载。2、去系统之家下载,我自己的win10就是从哪里下载安装的,你可以试试哈。ghost镜像的使用一、备份主分区--C盘:假设你的操作系统安装在主分区--C盘,当系统重装不久,或...

联想台式机重装系统按哪个键

联想电脑第一部,如果像进入装系统的界面,必须按f8,if8进入装系统的界面,这时候把下载好的U盘系统安装包直接插在主机上,直接就可以安装系统了,大概20分钟后就可以安装系统,安装系统就可以正常使用了...

360无法卸载怎么办(360卸载不了最简单三个步骤)

开启了自我保护,关闭即可。解决方法如下:准备材料:360安全卫士、电脑1、在电脑上打开安全卫士,进去之后,点击右上方的列表图标,选择设置,2、进去安全卫士设置界面之后,点击安全防护中心,3、进去安全防...

戴尔笔记本电脑没有声音怎么解决

右击“我的电脑”----“属性”---“硬件”----“设备管理器”,打开“声音、视频和游戏控制器”有无问题,即看前面有没有出现黄色的小图标,如有,重新安装这个设备的驱动程序进行解决。加强麦克风:右...

如何给无线路由器设置密码(如何给无线路由器设置密码教程)

1、使用路由器的管理界面,找到密码设置选项,输入想要设置的新密码。   2、再次输入新密码,以便确认输入的密码正确无误。   3、保...

windows7旗舰版激活序列号(win7旗舰 激活码)

一、Windows7旗舰版激活密钥零售版:Windows7UltimateRetail永久序列号【尝试联网激活,如果不能激活,可电话激活】[Key]:RHTBY-VWY6D-QJRJ9-JGQ...

联想电脑如何重置系统(联想电脑 重置系统)

联想进入bios界面重置系统方法:1、将电脑关机,按下一键恢复按钮(需确保笔记本屏盖在打开状态),不同的联想笔记本机型按钮位置不同,操作也不一样1)如果是此按钮,按住5秒钟等待出现还原界面2)针孔式按...

电脑加密文件夹怎么弄(电脑加密文件夹怎么弄出来)

要在电脑中加密文件夹,可以使用加密软件或操作系统提供的加密功能。使用加密软件,你可以选择文件夹并设置密码来保护其内容。这样,只有输入正确密码的人才能访问文件夹中的文件。另外,某些操作系统也提供了加密文...