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

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

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

前言

  • 单机游戏开发过程中,一款高效便捷的本地数据存储库一定是必不可少的。今天介绍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中的使用。

相关推荐

GCI: Another key public good for international community

MembersofadelegationofhighschoolstudentsfromtheU.S.stateofWashingtonposeforaphotoa...

kube on kube 实现思路分享(kube-scheduler)

这里的kubeonkube,是指建立K8s元集群,纳管其他业务K8s集群,通过声明式API管理集群的创建、增删节点等。参考https://github.com/kubean-i...

China and India hold the key to a more inclusive global future

ByMayaMajueranLead:AsChinaandIndiamark75yearsofdiplomaticties,theircooperationcouldse...

日本真子公主的婚礼又要提上日程了吗?未婚夫:债务问题已解决

日本明仁天皇将于今年3月31日退位,德仁皇太子即将成为新一任的天皇。在平成时代最后的倒计时中,明仁天皇的孙女真子公主的婚事却又一次进入了人们的视野。(viaTheTelegraph)关注日本皇室的...

kratos源码分析系列(1)(kvm源码解析与应用 pdf)

https://github.com/go-kratos/kratos是b站开源的一个微服务框架,整体来看它结合grpc生态中的grpc-gateway,以及wire依赖注入和众多常用的trace,m...

【2.C#基础】6.循环语句(c#循环语句例子)

6.循环语句当需要多次执行同一个处理时,就需要用到循环语句。一般情况下,循环的流程图如下:6.1while循环C#中的while循环语句在给定的条件为真的情况下会重复执行目标语句。格式如下:...

使用 Google Wire 在 Go 中进行依赖注入

关注点分离、松耦合系统和依赖反转原则等概念在软件工程中是众所周知的,并且在创建良好的计算机程序过程中至关重要。在本文中,我们将讨论一个同时应用了这三个原则的技术,称为依赖注入。我们将尽可能地实践,更加...

用 Golang封装你的API(golang封装dll)
用 Golang封装你的API(golang封装dll)

每日分享最新,最流行的软件开发知识与最新行业趋势,希望大家能够一键三连,多多支持,跪求关注,点赞,留言。@头条创作挑战赛本文探讨了在用Golang封装你的API的过程以及几个不同的编程步骤。我做了一个非常有限的时间来证明如何为客户正在开...

2025-05-09 20:03 liuian

Terraform 实战 | 万字长文(terrify是什么意思中文)

Terraform是什么Terraform(https://www.terraform.io/)是HashiCorp旗下的一款开源(Go语言开发)的DevOps基础架构资源管理运维工具,可...

Go 语言入门:环境安装(go语言安装 window)

一、前言这里不同于其他人的Go语言入门,环境安装我向来注重配置,比如依赖包、缓存的默认目录。因为前期不弄好,后面要整理又影响这影响那的,所以就干脆写成文章,方便后期捡起。二、安装1.安装包htt...

Go语言进阶之Go语言高性能Web框架Iris项目实战-项目结构优化EP05

前文再续,上一回我们完成了用户管理模块的CURD(增删改查)功能,功能层面,无甚大观,但有一个结构性的缺陷显而易见,那就是项目结构过度耦合,项目的耦合性(Coupling),也叫耦合度,进而言之,模块...

如何将Go项目与Docker结合实现高效部署

在现代软件开发中,使用Docker部署应用程序已经成为一种标准实践。本文将深入探讨如何将Go项目与Docker结合,实现高效、可靠的部署过程。通过详细的步骤和丰富的示例,你将能够迅速掌握这一流程。准备...

五分钟轻松熟悉一个k8s Operator应用制作

简介:operator是一种kubernetes的扩展形式,可以帮助用户以Kubernetes的声明式API风格自定义来管理应用及服务,operator已经成为分布式应用在k8s集群部...

程序员的副业秘籍!一款可以快速搭建各类系统的后台管理系统

系统简介这是一个基于Gin+Vue+ElementUI(或ArcoDesign、AntDesign)的系统快速开发平台,采用了前后端分离,旨在帮助用户快速完成各类系统的基础功能搭建。平...

使用 Go 语言开发区块链钱包的项目目录结构设计

在开发区块链钱包时,项目的目录结构应该清晰、模块化,确保代码的可维护性和扩展性。基于Go的惯例,结合区块链钱包的功能需求,以下是一个较为合理的目录结构示例:1.目录结构blockchain-wa...