首先,我们要从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

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

  1. 基于三层架构下的公共数据访问方法(Sqlite数据库)

    作者总结了一下,使用Winform的三层架构做窗体应用程序,在数据访问方面,有用到纯sql语句方法.参数方法.存储过程方法. 那么什么是三层架构呢? UI---存放Form窗体---(用户所关心的) ...

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

    ASP.net与SQLite数据库通过js和ashx交互(连接和操作): 废话(也是思路):用的是VS2010,打算做网站前后台.由于不喜欢前台语言里加些与html和css和js的其他内容,想实现前后 ...

  3. 在IOS中使用DES算法对Sqlite数据库进行内容加密存储并读取解密

    在IOS中使用DES算法对Sqlite 数据库进行内容加密存储并读取解密 涉及知识点: 1.DES加密算法: 2.OC对Sqlite数据库的读写: 3.IOS APP文件存储的两种方式及读取方式. 以 ...

  4. android中与SQLite数据库相关的类

    为什么要在应用程序中使用数据库?数据库最主要的用途就是作为数据的存储容器,另外,由于可以很方便的将应用程序中的数据结构(比如C语言中的结构体)转化成数据库的表,这样我们就可以通过操作数据库来替代写一堆 ...

  5. 讨论SQLite数据库损坏与修复

      版权声明:博客将逐步迁移到 http://cwqqq.com https://blog.csdn.net/cwqcwk1/article/details/45541409 昨晚,朋友和我反馈SQL ...

  6. Sqlite 数据库出现database disk image is malformed报错的解决方法

    软件用的是Sqlite数据库,昨天还好好的,今天开机登录软件报错:database disk image is malformed 用Sqlite Expert Personal 重建索引,发现其中一 ...

  7. VS中引用第三方库的方法(配置sqlite数据库)

    我们在编写程序时,,不可避免的会使用第三方的库文件,很少使用源文件(.cpp),大部分是使用对类进行声明的头文件和封装了类的链接库(静态lib或动态dll),比如我们写程序用的iostream这个库, ...

  8. C#连接SQLite数据库方法

    --结合Enterprise Library连接,操作SQLite 企业库是我们常用的框架之一,可以从http://entlib.codeplex.com/下载Enterprise Library 5 ...

  9. 使用安卓读取sqlite数据库方法记录

    最近要实现android读取sqlite数据库文件,在这里先做一个英汉字典的例子.主要是输入英语到数据库中查询相应的汉语意思,将其答案输出.数据库采用sqlite3. 如图: 实现过程完全是按照参考文 ...

随机推荐

  1. SpringBoot2.0 基础案例(03):配置系统全局异常映射处理

    一.异常分类 这里的异常分类从系统处理异常的角度看,主要分类两类:业务异常和系统异常. 1.业务异常 业务异常主要是一些可预见性异常,处理业务异常,用来提示用户的操作,提高系统的可操作性. 常见的业务 ...

  2. 两数相加LeetCode

    给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和 ...

  3. Python命名空间和作用域

    准备知识: 1.在Python解释器开始执行之后,机会在内存中开辟一个空间,每当遇到 一个变量的时候,就把变量和值之间的关系记录下来,但是当遇到函数定义 的时候,解释器只是把函数名读入内存,表示这个函 ...

  4. Python网络编程之基础

    计算机网络基础 网络到底是什么?计算机之间如何通信的? 早期:联机 以太网:局域网与交换机 ******广播 主机之间“一对所有”的通讯模式,网络对其中每一台主机发出的信号都进行无条件复制并转发, 所 ...

  5. 关于JS点击button之灵活替换改变内容方法

    <p id="demo">JavaScript 能改变 HTML 元素的内容.</p> <script>function myFunction( ...

  6. 题解 P1854 花店橱窗布置

    把二维压成一维的DP了解一下... 传送门 (以纪念神经兮兮调了两天的一维DP(刷水题谋财害命)以及感谢学长的帮助@ydnhaha) 显然我们有二维的dp:f[i][j]代表第i盆花放到第j个位置 ; ...

  7. 几款常用的高质量web前端框架

    http://blog.csdn.net/qianduankuangjia/article/details/78042944

  8. NET CORE 基础

    NET CORE 基础管理系统 [SF]开源的.NET CORE 基础管理系统 - 安装篇   [SF]开源的.NET CORE 基础管理系统 -系列导航 1.开发必备工具 IDE:VS2017 运行 ...

  9. 关系型数据库---MySQL---数据表

    1.在创建一个新的MySQL数据表时,可以为它设置一个类型: 2.MySQL支持多种数据表类型,有各自的特点和属性,最重要的3种类型: 1.1 MyISAM 1.2 InnoDB 1.1 可以把Inn ...

  10. jsfiddle.net上的记录

    1.JQuery: http://jsfiddle.net/uryc1908/ 2.e-chart: http://jsfiddle.net/8fq96a7s/ 3.easyUI http://jsf ...