unity3d sqlite数据库的读写方法

  首先,我们要从unity的安装路径中复制mono.data.sqlite.dll和sqlite3.dll两个动态链接库到untiy的plugins目录下,如下图所示:

使用navicat for sqlite创建一个sqlite数据库文件,放到Resources文件夹目录中,如下图所示:

新建一个DbAccess脚步,添加以下脚步:

using UnityEngine;

using System;

using System.Collections;

using Mono.Data.Sqlite;

using System.IO;

public class DbAccess  {

private SqliteConnection dbConnection;//sql连接

private SqliteCommand dbCommand=null;//sql命令

private SqliteDataReader dbReader;//sql读取器

public DbAccess(string connectionString)

{

string appDBPath = "";

if(Application.platform == RuntimePlatform.WindowsEditor)//如果是windows编辑器中

{

appDBPath = Application.dataPath+"//"+connectionString;

}

else if(Application.platform == RuntimePlatform.Android)--如果是安卓平台

{

appDBPath = Application.persistentDataPath +"/" + connectionString;

if (!File.Exists(appDBPath))

{

WWW loader = new WWW("jar:file://" + Application.dataPath + "/" + connectionString);//把数据库复制到安卓可写路径中,注:sqlite不能在安装包中读取数据

File.WriteAllBytes(appDBPath,loader.bytes);

}

}

OpenDB("Data Source="+appDBPath);

}

private void OpenDB(string connectionString)

{

try

{

dbConnection = new SqliteConnection(connectionString);

dbConnection.Open();

Debug.Log("connect to db");

}

catch (System.Exception ex)

{

Debug.Log(ex.Message);

}

}

public void CloseSqlConnection()//关闭数据库连接

{

if (dbCommand!=null)

dbCommand.Dispose();

dbCommand = null;

if (dbReader!=null)

dbReader.Dispose();

dbReader = null;

if (dbConnection!=null)

dbConnection.Close();

dbConnection = null;

}

public SqliteDataReader ExecuteQuery(string sqlQuery)//执行查询

{

dbCommand = dbConnection.CreateCommand();

dbCommand.CommandText = sqlQuery;

dbReader = dbCommand.ExecuteReader();

return dbReader;

}

public SqliteDataReader ReadFullTable(string tableName)//读取整个表

{

string query = "SELECT * FROM " + tableName+";";

return ExecuteQuery(query);

}

public SqliteDataReader InsertInto(string tableName,string[] values)//在表中插入数据

{

string query = "INSERT INTO " + tableName + " VALUES(‘" + values[0];

for (int i = 1; i < values.Length;i++ )

{

query += "‘,‘" + values[i];

}

query += "‘)";

return ExecuteQuery(query);

}

public SqliteDataReader UpdateInto(string tableName,string[] cols,string colsValues,string selectKey,string selectValue)//替换表中数据

{

string query = "UPDATE " + tableName + " SET " + cols[0] + " = " + colsValues[0];

for (int i = 1; i < colsValues.Length; ++i)

{

query += ", " + cols[i] + " =" + colsValues[i];

}

query += " WHERE " + selectKey + " = " + selectValue + " ";

return ExecuteQuery(query);

}

public SqliteDataReader Delete(string tableName, string[] cols, string[] colsvalues)//删除表中数据

{

string query = "DELETE FROM " + tableName + " WHERE " + cols[0] + " = " + colsvalues[0];

for (int i = 1; i < colsvalues.Length; ++i)

{

query += " or " + cols[i] + " = " + colsvalues[i];

}

return ExecuteQuery(query);

}

public SqliteDataReader InsertIntoSpecific (string tableName, string[] cols, string[] values)//插入特定值

{

if (cols.Length != values.Length) {

throw new SqliteException ("columns.Length != values.Length");

}

string query = "INSERT INTO " + tableName + "(" + cols[0];

for (int i = 1; i < cols.Length; ++i) {

query += ", " + cols[i];

}

query += ") VALUES (" + values[0];

for (int i = 1; i < values.Length; ++i) {

query += ", " + values[i];

}

query += ")";

return ExecuteQuery (query);

}

public SqliteDataReader DeleteContents (string tableName)//删除表

{

string query = "DELETE FROM " + tableName;

return ExecuteQuery (query);

}

public SqliteDataReader CreateTable (string name, string[] col, string[] colType)//创建表

{

if (col.Length != colType.Length) {

throw new SqliteException ("columns.Length != colType.Length");

}

string query = "CREATE TABLE " + name + " (" + col[0] + " " + colType[0];

for (int i = 1; i < col.Length; ++i) {

query += ", " + col[i] + " " + colType[i];

}

query += ")";

return ExecuteQuery (query);

}

public SqliteDataReader SelectWhere (string tableName, string[] items, string[] col, string[] operation, string[] values)//集成所有操作后执行

{

if (col.Length != operation.Length || operation.Length != values.Length) {

throw new SqliteException ("col.Length != operation.Length != values.Length");

}

string query = "SELECT " + items[0];

for (int i = 1; i < items.Length; ++i) {

query += ", " + items[i];

}

query += " FROM " + tableName + " WHERE " + col[0] + operation[0] + "‘" + values[0] + "‘ ";

for (int i = 1; i < col.Length; ++i) {

query += " AND " + col[i] + operation[i] + "‘" + values[0] + "‘ ";

}

return ExecuteQuery (query);

}

}

使用事例:

数据库的Dialog表中有一下数据:

DbAccess db = new DbAccess("/Resources/DazzleParkour.sqlite");

using (SqliteDataReader reader = db.SelectWhere("Dialog", new string[] { "id,Name,FileName,Scale" }, new string[] { "Scale" }, new string[] { "=" }, new string[] { "1" }))//读取出Scale等于1的数据

{

while (reader.Read())// 循环遍历数据

{

int name = reader.GetInt32(reader.GetOrdinal("id"));

Debug.Log(name);

}

reader.Close();

db.CloseSqlConnection();

}

最后打印的数据如下

在打包时,注意要把playersetting里的api解析等级改为.Net 2.0

时间: 2024-09-29 22:53:41

unity3d sqlite数据库的读写方法的相关文章

关于Android studio找不到sqlite数据库的解决方法

打开Android Device Monitor,剩下的与Eclipse相同.

ASP.net与SQLite数据库通过js和ashx交互(连接和操作)

ASP.net与SQLite数据库通过js和ashx交互(连接和操作): 废话(也是思路):用的是VS2010,打算做网站前后台.由于不喜欢前台语言里加些与html和css和js的其他内容,想实现前后台语言的分离,与前后台通过js的ajax实现交互,故很多百度出来的方法不成立,虽听说ashx过时,但是他实现了我要的效果:即前后台语言不是相互嵌入实现交互,而是通过js实现(有接口就可以).由于领导指定用SQLite,故这两天还折腾了SQLite,不过对于这种小型的网站,它是个很好的选择(不需要部署

讨论SQLite数据库损坏与修复

昨晚,朋友和我反馈SQLite数据库发生损坏有没有办法恢复.大致的情况是这样的,当数据库在使用时不小心用了新的文件覆盖数据库,导致了SQLite数据库出现了损坏,打开的时候出现要输入密码,而且不能把SQL语句dump下来.所以,文章这里整理SQLite数据库出现损坏的所有情况,以及如何修复损坏的SQLite数据库文件. SQLite算是非常稳定的数据库,不容易出现损坏,就算应用程序崩溃,或者操作系统崩溃,甚至是执行事务时出现断电,都能在下一次使用数据库时自动修复.但是,还是不能避免不出现损坏的情

【Unity3D】使用MD5值,确保本地Sqlite数据库内容没有被篡改

Sqlite的应用场景 在判断是否使用存储格式为Sqlite模式的标准,我们的标准是内容只读.也就是说,除非发布者修改Sqlite内容,玩家只有读取的权限. 换个角度说,Sqlite里面的数据都是游戏基础配置数据,比如游戏的关卡(不包括玩家取得的成就).怪物的血量.装备的模板数据 对于如何使用Sqlite,请参考我的另外一篇文章<Unity本地数据存储---Sqlite和JSON> 问题重现 OK,既然我们选择了Sqlite作为存储手段之一,那么我们也嘚重视起安全性. 以android而言,我

一种远程修改sqlite数据库的方法

一.实际需求 工业设备DA660是专门用来实现工业上可编程设备之间交换信息的交换机.现在要使得DA660采集下行设备的实时数据,然后传送到上位机显示.上位机还可以远程修改DA660的数据库配置. 二.数据库设计 我在DA660中设计了sqlite3数据库,名为da660.db,里面存放很多表,其中有一张表示baseinfo,其结构定义如下: 通道号是从0到15之间的正整数,从机地址是从0到256之间的正整数,设备类型定义为0到5之间的正整数,设备类型可从{"xz2000", "

winform中读写SQLite数据库例子(转)

.Net SQLite数据库驱动以及System.Data.SQLite.dll下载最新地址: http://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki SQLite管理工具下载地址: http://www.cr173.com/soft/94247.html App.config文件修改: [html] view plaincopyprint? <?xml version="1.0"?> &l

cordova调用本地SQLite数据库的方法

第一篇技术博客,写下来和大家分享今天所学,其次自己也巩固一下. 整个下午的时间用来钻研如何用cordova调用移动端本地SQLite数据库.首先我并不是用eclipse来编程的,而是用cordova建立project后直接用notepad编辑www下的index文件. 一.cordova的下载安装和建立project的方法 该部分不是文章重点,抽空另开一篇文章详细介绍.官网上有相关教程:http://cordova.apache.org/docs/en/5.0.0/guide_cli_index

C#连接SQLite数据库方法

--结合Enterprise Library连接,操作SQLite 企业库是我们常用的框架之一,可以从http://entlib.codeplex.com/下载Enterprise Library 5.0.msi.安装之后有源代码和chm的文档.里面的很多思想更值得我们程序员去研究.企业库中的数据访问组件更是我们常用的数据访问组件之一.组件默认支持SQL Server和Oracle的数据库访问,支持自定义的扩展. --使用企业库操作SQLite数据库 需要用到企业库的一个扩展组件,Enterpr

Navicat for SQLite 连接Sqlite数据库的方法

Navicat for SQLite 配备了数据编辑.SQL查询和数据模型工具,并支持所有SQLite对象类型.其主要功能有数据传输.数据同步.导入或导出.报表等.其凭借设计的方便快捷的用户界面,并且用户创建.组织.访问和共享信息都非常的简便快捷,优化SQLite工作流程,提高工作效率.下面我们将给大家介绍介绍Navicat for SQLite 连接Sqlite数据库的方法? 原文:http://www.formysql.com/jiqiao/sqlite-lianjie.html Navic