Unity—Mono.Data.Sqlite

这篇具有很好参考价值的文章主要介绍了Unity—Mono.Data.Sqlite。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Mono.Data.Sqlite

一、常用属性
Depth:获取一个值,用于指示当前行的嵌套深度
FieldCount:获取当前行中的列数
HasRows:获取一个值,该值指示SQLDataReader是否有行
IsClosed:指定的SQLDataReader实例是否已关闭
Item[Int32]:获取指定列(数字索引),通常在While.Read()中使用
Item[String]:获取指定列(字符串索引),通常在While.Read()中使用
RecordsAffected:获取执行SqlDataReader中未隐藏的字段数目

class Program
    {
        static void Main(string[] args)
        {
            string str = "server=.;database=JunTest;uid=sa;pwd=123;Asynchronous Processing=true";
            SqlConnection conn = new SqlConnection(str);    //创建连接
            SqlCommand cmd = conn.CreateCommand();          //创建SqlCommand对象
            cmd.CommandText = "SELECT * FROM Person";
            conn.Open();                            //打开连接
 
            using (SqlDataReader reader = cmd.ExecuteReader())
            {
                Console.WriteLine(reader.FieldCount);   //2  获取列数
                Console.WriteLine(reader.Depth);        //0  嵌套深度
                Console.WriteLine(reader.HasRows);      //true  是否包含行
                Console.WriteLine(reader.IsClosed);     //false SqlDataReader是否关闭 
                Console.WriteLine(reader.RecordsAffected);      //-1 执行T-SQL语句所插入、修改、删除的行数
                Console.WriteLine(reader.VisibleFieldCount);    //2  未隐藏的字段数目(一共就两列)
 
                while (reader.Read())
                {
                    Console.WriteLine(reader["PersonName"]);
                  //Console.WriteLine(reader[1]);   通过数字索引或字符串索引访问
                }
            }
 
            conn.Close();                           //关闭连接
            Console.ReadKey();
        }
    }

二、常用方法
Read:前进到下一记录,异步版本ReadAsync
GetString:返回指定类型的值,其他的类型
NextResult:当处理批批处理T-SQL语句时,跳到下一结果 异步版本NextResultAsync
GetValue:获取该列的值,返回object类型
GetValues:使用当前列,来填充参数中的对象数组
Close:关闭SqlDataReader对象

class Program
    {
        static void Main(string[] args)
        {
            string str = "server=.;database=JunTest;uid=sa;pwd=123;Asynchronous Processing=true";
            SqlConnection conn = new SqlConnection(str);    //创建连接
            SqlCommand cmd = conn.CreateCommand();          //创建SqlCommand对象
            cmd.CommandText = "SELECT * FROM Person";
            conn.Open();                            //打开连接
 
            using (SqlDataReader reader = cmd.ExecuteReader())
            {
                while (reader.Read())
                {
                    Console.WriteLine(reader.IsDBNull(1));      //是否是null值
                    Console.WriteLine(reader.GetString(1));     //Get什么类型就返回什么类型,这没啥好说的。
                }
                Console.WriteLine(reader.GetName(1));               //PersonName 由数字获得列名
                Console.WriteLine(reader.GetOrdinal("PersonName")); //1 由列名获取其在reader中的数字索引
 
                if (reader.NextResult())
                {
                    Console.WriteLine(reader.GetString(1));
                }
            }
            conn.Close();                           //关闭连接
            Console.ReadKey();
        }
    }

Demo :文章来源地址https://www.toymoban.com/news/detail-437215.html

using UnityEngine;
using System;
using System.Collections;
using Mono.Data.Sqlite;
/// <summary>
/// SQLite数据库操作类
/// </summary>
public class SqliteAccess
{
	private SqliteConnection conn; // SQLite连接
	private SqliteCommand cmd; // SQLite命令
	private SqliteDataReader reader;
	public SqliteAccess(string connectionString)
	{
		OpenDB(connectionString);
	}
	public SqliteAccess() { }
	/// <summary>
	/// 打开数据库
	/// </summary>
	/// <param name="connectionString"></param>
	public void OpenDB(string connectionString)
	{
		try
		{
			conn = new SqliteConnection(connectionString);
			conn.Open();
			Debug.Log("Connected to db,连接数据库成功!");
		}
		catch (Exception e)
		{
			string temp1 = e.ToString();
			Debug.Log(temp1);
		}
	}
	/// <summary>
	/// 关闭数据库连接
	/// </summary>
	public void CloseSqlConnection()
	{
		if (cmd != null) { cmd.Dispose(); cmd = null; }
		if (reader != null) { reader.Dispose(); reader = null; }
		if (conn != null) { conn.Close(); conn = null; }
		Debug.Log("Disconnected from db.关闭数据库!");
	}
	/// <summary>
	/// 执行SQL语句
	/// </summary>
	/// <param name="sqlQuery"></param>
	/// <returns></returns>
	public SqliteDataReader ExecuteQuery(string sqlQuery)
	{
		cmd = conn.CreateCommand();
		cmd.CommandText = sqlQuery;
		reader = cmd.ExecuteReader();
		return reader;
	}

	/// <summary>
	/// 查询表中全部数据 param tableName=表名 
	/// </summary>
	public SqliteDataReader ReadFullTable(string tableName)
	{
		string query = "SELECT * FROM " + tableName;
		return ExecuteQuery(query);
	}
	/// <summary>
	/// 插入数据 param tableName=表名 values=插入数据内容
	/// </summary>
	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);
	}
	/// <summary>
	/// 更新数据 param tableName=表名 cols=更新字段 colsvalues=更新内容 selectkey=查找字段(主键) selectvalue=查找内容
	/// </summary>
	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);
	}

	/// <summary>
	/// 删除数据 param tableName=表名 cols=字段 colsvalues=内容
	/// </summary>
	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);
	}
	/// <summary>
	/// 插入数据 param tableName=表名 cols=插入字段 value=插入内容
	/// </summary>
	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);
	}
	/// <summary>
	/// 删除表中全部数据
	/// </summary>
	public SqliteDataReader DeleteContents(string tableName)
	{
		string query = "DELETE FROM " + tableName;
		return ExecuteQuery(query);
	}
	/// <summary>
	/// 创建表 param name=表名 col=字段名 colType=字段类型
	/// </summary>
	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);
	}
	/// <summary>
	/// 按条件查询数据 param tableName=表名 items=查询字段 col=查找字段 operation=运算符 values=内容
	/// </summary>
	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[i] + "' ";
		}
		return ExecuteQuery(query);
	}
	/// <summary>
	/// 查询表
	/// </summary>
	public SqliteDataReader Select(string tableName, string col, string values)
	{
		string query = "SELECT * FROM " + tableName + " WHERE " + col + " = " + values;
		return ExecuteQuery(query);
	}
	public SqliteDataReader Select(string tableName, string col, string operation, string values)
	{
		string query = "SELECT * FROM " + tableName + " WHERE " + col + operation + values;
		return ExecuteQuery(query);
	}
	/// <summary>
	/// 升序查询
	/// </summary>
	public SqliteDataReader SelectOrderASC(string tableName, string col)
	{
		string query = "SELECT * FROM " + tableName + " ORDER BY " + col + " ASC";
		return ExecuteQuery(query);
	}
	/// <summary>
	/// 降序查询
	/// </summary>
	public SqliteDataReader SelectOrderDESC(string tableName, string col)
	{
		string query = "SELECT * FROM " + tableName + " ORDER BY " + col + " DESC";
		return ExecuteQuery(query);
	}
	/// <summary>
	/// 查询表行数
	/// </summary>
	public SqliteDataReader SelectCount(string tableName)
	{
		string query = "SELECT COUNT(*) FROM " + tableName;
		return ExecuteQuery(query);
	}
}
using Mono.Data.Sqlite;
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class User : MonoBehaviour
{
    private SqliteAccess db;
    protected SqliteDataReader reader;
    private string dbName = "sqlite.db";
    
    private void Start()
    {
        OpenDB();

        reader = db.ReadFullTable("User");

        for(int i = 0; i < reader.VisibleFieldCount; i++)
        {
            Debug.Log(reader.GetName(i)+"--"+reader.GetValue(i));
        }
        while (reader.Read())
        {
            Debug.Log(reader["username"]);
            //Console.WriteLine(reader[1]);   通过数字索引或字符串索引访问
        }

        reader.Close();
    }  
}

到了这里,关于Unity—Mono.Data.Sqlite的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Unity 景深Depth Of Field

    目录   介绍 准备 设置 基于Unity Builtin 管线 基于Unity URP 基于Unity HDRP   景深效果Depth Of Field是摄影界的老常客了,在游戏中也非常多见,它能够大幅提升游戏画面体验和真实度,使得物体看起来更有细节。 GTA5中的景深效果 Unity 当然提供了景深支持: Creative Core: Post-processi

    2024年02月09日
    浏览(39)
  • Unity框架学习--4 Mono管理器

    作用 :使不继承MonoBehaviour的类能够开启协程,并且可以使用FixedUpdate、Update、LateUpdate进行每帧更新。 原理: 1、在场景中创建一个继承MonoBehaviour的“执行者”脚本,这个脚本就专门用来开启协程和监听帧更新。 2、Mono管理器访问这个“执行者”脚本,就可以实现所需的效果

    2024年02月13日
    浏览(39)
  • Unity框架与.NET, Mono框架的关系

    什么是C# C#是一种面向对象的编程语言。 什么是.NET .NET是一个开发框架,它遵循并采用CIL(Common Intermediate Language)和CLR(Common Language Runtime)两种约定, CIL标准为一种编译标准:将不同编程语言(C#, JS, VB等)使用各自的编译器,按照统一的标准编译成语义一致的CIL中间码, 这样虽

    2024年02月07日
    浏览(37)
  • 【CodeSmith】The System.Data.SQLite library is not installed on this computer,不能使用SQLite解决办法

    1)System.Data.SQLite 尚未安装在您的计算机上 2)System.Data.SQLite 尚未正确配置 【注意】CodeSmith Generator 被编译为 AnyCPU。这意味着当您在Visual Studio外部启动Generator时,Generator将作为64位进程运行。如果从 Visual Studio(32 位进程)中生成,则 CodeSmith 生成器库将作为 32 位进程运行。

    2024年02月09日
    浏览(51)
  • 2023年Unity Il2CPP/MONO FPS逆向工程

    实战引擎 : Unity Il2CPP/Mono 学完可做 : 森林之子,后室,逃离塔科夫,BattleBit,Rust等 几乎通杀全部Unity引擎游戏 简介: 实战编程代码:C/C++ B站空间:https://space.bilibili.com/2134677790 课程详细目录 :2023年Unity Il2CPP/MONO FPS逆向工程 · 语雀 联系方式 :点击课程详细目录查看 效果图

    2024年02月13日
    浏览(42)
  • Mac vscode unity mono无法正常加载,c#代码不能正常补全的解决方法

    初学unity,用Mac vscode来开发,遇见了不能正常补全代码的问题。能补全代码但是补全的不是unity的代码。 终于解决了。 首先最新版的net.sdk 和 Mono (Stable channel)一定安装好 https://www.mono-project.com/download/stable/ https://learn.microsoft.com/ja-jp/dotnet/core/install/macos vscode里边该有的扩展插件

    2024年02月02日
    浏览(44)
  • Unity UI与粒子 层级问题Camera depth Sorting Layer Order in Layer RenderQueue

    Unity游戏开发中,模型、界面、特效等,需要规划好 layer 的概念,涉及到摄像机(Camera)、画布(Canvas)、Shader等相关内容。 在 Unity 中,渲染顺序是由多个因素共同决定的,大致分为三层优先级: Camera depth、Sorting Layer/Order in Layer 和 RenderQueue 。 一般游戏项目,会创建至少两

    2024年02月08日
    浏览(41)
  • Unity Meta Quest MR 开发(四):使用 Scene API 和 Depth API 实现深度识别和环境遮挡

    此教程相关的详细教案,文档,思维导图和工程文件会放入 Spatial XR 社区 。这是一个高质量 XR 社区,博主目前在内担任 XR 开发的讲师。此外,该社区提供教程答疑、及时交流、进阶教程、外包、行业动态等服务。 社区链接: Spatial XR 高级社区(知识星球) Spatial XR 高级社区

    2024年02月20日
    浏览(48)
  • HTML5中的data-*属性

    介绍: data-*全局属性是一类被称为自定义数据属性的属性,它赋予我们在所有 HTML 元素上 嵌入自定义数据属性 的能力。 在js里有两种获取方法: 第一种 :     第二种:  setAttribute()修改属性值:   css中使用:  使用属性选择器

    2024年02月14日
    浏览(38)
  • 【前端】jquery获取data-*的属性值

     通过jquery获取下面data-id的值 方法一:dataset()方法 方法二:jquery data()方法 通过点击事件,获取当前被点击的属性值 方法三:jquery attr()方法

    2024年02月07日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包