莱莱 发表于 2024-9-17 17:52:08

在unity中利用内嵌数据库sqlite

前言



[*]这个任务是因为我在给别人写外包,必要数据库。
[*]假如利用MySQL,实在是太笨重了,必要额外安装MySQL这个软件
[*]所以我决定用sqlite这个嵌入式数据库。
网络上两种环境



[*] 第一种是利用这两个dll来进行毗连并创建,在本身电脑上就可以很轻易的找到,我这里利用的是everythingTool工具,所以比较方便找到了。
https://i-blog.csdnimg.cn/blog_migrate/c32a1000e1cbb02add0bfad31f3c1bfb.png
https://i-blog.csdnimg.cn/blog_migrate/dde9eabff21beddb1b18b6bf91b8dea7.png
[*] 视频教程B站视频
[*] 第二种是github上某人写的一个毗连库
视频教程
[*] 我这里利用的是第二种
[*] 数据库可视化工具用的sqliteStudio
[*] GitHub毗连
如何利用



[*]导入插件
插件
[*]写脚本,毗连数据库。
[*]再者,创建数据表
[*]留意事项
[*]1.他这个插件会根据你的类自动创建对应的表的表头,假如你必要主键,就必要继承IPrimaryKey
[*]而且因为我没找到怎么让她自动天生主键,所以我是本身用Guid来填充的
[*]2.在测试阶段退出player后肯定要关闭和数据库的connection,否则你没有办法删除天生的表。
三个脚本



[*]脚本是我根据插件里面自带的例子更改而成的
[*]model模型类,用来对表的数据做映射
[*]Table类-提供基本的对表的增编削查的操作,比如按照ID搜索,按照名字搜索等等。
[*]ModelManager,用table的方法来提供对上层的支持
using SQLite4Unity3d;
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public enum Role
{
    None = 0,
    InWork = 1,
    LoseWork = 2,
    ExitWork = 3,
    Other = 4,
}

public enum Major
{
    None = 0,
    Machine = 1,
    NotMachine = 2
}

public interface IPrimaryKey
{
    public string ID { get; set; }
}
public class User : IPrimaryKey
{
   
    public string ID { get; set; }
    public string UserName { get; set; }
    public string Password { get; set; }
    public Role Role { get; set; } = Role.None;
    public string Name { get; set; }
    public int StudyNumber { get; set; }
    public Major MajorCode { get; set; }

}



[*]通用的表类
using SQLite4Unity3d;
using UnityEngine;
#if !UNITY_EDITOR
using System.Collections;
using System.IO;
#endif
using System.Collections.Generic;


public class UserTable : TableService<User>
{

    public User FindByUserName(string name)
    {
      return _connection.Table<User>().Where(x => x.UserName == name).FirstOrDefault();
    }
}
public class TableService<T> where T : IPrimaryKey, new()
{

    protected static SQLiteConnection _connection;


    public static void DisConnect()
    {
      _connection.Dispose();
    }

    const string DatabaseName = "Crane.db";
    static TableService()
    {

#if UNITY_EDITOR
      var dbPath = string.Format(@"Assets/StreamingAssets/{0}", DatabaseName);
#else
      // check if file exists in Application.persistentDataPath
      var filepath = string.Format("{0}/{1}", Application.persistentDataPath, DatabaseName);

      if (!File.Exists(filepath))
      {
            Debug.Log("Database not in Persistent path");
            // if it doesn't ->
            // open StreamingAssets directory and load the db ->

#if UNITY_ANDROID
            var loadDb = new WWW("jar:file://" + Application.dataPath + "!/assets/" + DatabaseName);// this is the path to your StreamingAssets in android
            while (!loadDb.isDone) { }// CAREFUL here, for safety reasons you shouldn't let this while loop unattended, place a timer and error check
            // then save to Application.persistentDataPath
            File.WriteAllBytes(filepath, loadDb.bytes);
#elif UNITY_IOS
               var loadDb = Application.dataPath + "/Raw/" + DatabaseName;// this is the path to your StreamingAssets in iOS
                // then save to Application.persistentDataPath
                File.Copy(loadDb, filepath);
#elif UNITY_WP8
                var loadDb = Application.dataPath + "/StreamingAssets/" + DatabaseName;// this is the path to your StreamingAssets in iOS
                // then save to Application.persistentDataPath
                File.Copy(loadDb, filepath);

#elif UNITY_WINRT
                var loadDb = Application.dataPath + "/StreamingAssets/" + DatabaseName;// this is the path to your StreamingAssets in iOS
                // then save to Application.persistentDataPath
                File.Copy(loadDb, filepath);
               
#elif UNITY_STANDALONE_OSX
                var loadDb = Application.dataPath + "/Resources/Data/StreamingAssets/" + DatabaseName;// this is the path to your StreamingAssets in iOS
                // then save to Application.persistentDataPath
                File.Copy(loadDb, filepath);
#else
        var loadDb = Application.dataPath + "/StreamingAssets/" + DatabaseName;// this is the path to your StreamingAssets in iOS
        // then save to Application.persistentDataPath
        File.Copy(loadDb, filepath);

#endif

            Debug.Log("Database written");
      }

      var dbPath = filepath;
#endif
      _connection = new SQLiteConnection(dbPath, SQLiteOpenFlags.ReadWrite | SQLiteOpenFlags.Create);
      Debug.Log("Final PATH: " + dbPath);
      var count = _connection.GetTableInfo(typeof(T).Name).Count;
      //创建对应的Table
      if (count == 0)
      {
            _connection.CreateTable<T>();
      }

    }

    public int InsertData(T obj)
    {
      return _connection.Insert(obj);
    }

    public int Delete(T obj)
    {
      return _connection.Delete(obj);
    }

    public int Update(T obj)
    {
      return _connection.Update(obj);
    }

    public T FindByID(string ID)
    {
      return _connection.Table<T>().Where(x => x.ID == ID).FirstOrDefault();

    }


    //public void CreateDB<T>()
    //{
    //    _connection.CreateTable<T>();
    //}

    //public IEnumerable<Person> GetPersons()
    //{

    //    //_connection.
    //    return _connection.Table<Person>();
    //}

    //public IEnumerable<Person> GetPersonsNamedRoberto()
    //{
    //    return _connection.Table<Person>().Where(x => x.Name == "Roberto");
    //}

    //public Person GetJohnny()
    //{
    //    return _connection.Table<Person>().Where(x => x.Name == "Johnny").FirstOrDefault();
    //}

    //public Person CreatePerson()
    //{
    //    var p = new Person
    //    {
    //      Name = "Johnny",
    //      Surname = "Mnemonic",
    //      Age = 21
    //    };
    //    _connection.Insert(p);
    //    return p;
    //}
}



[*]ModelMaanger
using System;
using System.Collections;
using System.Collections.Generic;
using System.Security.Cryptography;
using System.Text;
using Unity.VisualScripting;
using UnityEngine;

public class ModelManager
{


    public static UserTable UserTable;

    public static ModelManager Inst { get; private set; } = new ModelManager();
    static ModelManager()
    {
      UserTable = new UserTable();
    }

    private ModelManager()
    {

    }

    public void OnQuit()
    {
      UserTable.DisConnect();
    }

    public void RegisterUser(User user)
    {
      user.ID = Guid.NewGuid().ToString();
      user.Password = EnCryption(user.Password + salt);
      UserTable.InsertData(user);
    }
    public bool IsExistName(string name, out User user)
    {
      var currUser = UserTable.FindByUserName(name);
      user = currUser;
      return currUser != null;
    }

    public bool IsExistName(string name)
    {
      var currUser = UserTable.FindByUserName(name);
      return currUser != null;
    }

    public void UpdatePassword(User user, string password)
    {
      user.Password = EnCryption(password + salt);
      UserTable.Update(user);
    }

    public bool IsMatchName(string name, string password, out bool passwordRight)
    {
      var currUser = UserTable.FindByUserName(name);
      if (currUser == null)
      {
            passwordRight = false;
            return false;
      }
      else
      {
            passwordRight = EnCryption(password + salt) == currUser.Password;
            return true;
      }
    }
    string salt = "sdsax";
    public string EnCryption(string content)
    {
      using (MD5 md5Hash = MD5.Create())
      {
            byte[] data = md5Hash.ComputeHash(Encoding.UTF8.GetBytes(content));

            StringBuilder builder = new StringBuilder();
            for (int i = 0; i < data.Length; i++)
            {
                builder.Append(data.ToString("x2")); // 将每个字节转换为十六进制并添加到结果中
            }

            return builder.ToString();
      }
    }
}


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 在unity中利用内嵌数据库sqlite