程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> unity3d,C#使用sqlite作為數據庫解決方案思路

unity3d,C#使用sqlite作為數據庫解決方案思路

編輯:C#入門知識

unity3d,C#使用sqlite作為數據庫解決方案思路


 


1,編輯器建立好數據庫結構,生成sqlite數據庫文件,可以用navicat圖形界面編輯器來操作。
2,建立好的數據庫,後綴名變為.txt格式(方便unity3d加載),放文件放到Assest/Resources目錄下(新建目錄)。
放在Resources目錄下的文件,在Pc/ios/android端均可以不作區分的用Resource來加載,假設數據庫文件名位:data.txt,語句如下:
TextAsset txt = Resources.Load ("data", typeof(TextAsset))as TextAsset;
3, 將讀取到的TextAsset文件寫入對應平台的沙盒路徑下, 代碼為:
databaseFilePath = Application.persistentDataPath+"//"+data.db;(沙盒,各平台路徑不同,均為可讀寫)
File.WriteAllBytes(databaseFilePath,txt.bytes);
4,加載沙盒路徑下的數據庫文件進行讀寫操作。DbAccess封裝了數據庫操作。其中需要兩個dll文件,一個so文件(android平台需要libsq

 

 

 


using UnityEngine;

 

using System.Collections;
using Mono.Data.Sqlite;
using System;
using System.IO;

public class DbAccess{

	private SqliteConnection dbConnection;
	
	private SqliteCommand dbCommand;
	
	private SqliteDataReader reader;
	
	public DbAccess (string connectionString)
	{
		OpenDB (connectionString);
	}
	public DbAccess ()
	{
		
	}

	public void OpenDB (string connectionString)
	{
		try
		{
			dbConnection = new SqliteConnection (connectionString);
			
			dbConnection.Open ();
			
			Debug.Log ("Connected to db");
		}
		catch(Exception e)
		{
			string temp1 = e.ToString();
			Debug.Log(temp1);
		}
	}
	
	public void CloseSqlConnection ()
	{
		
		if (dbCommand != null) {
			
			dbCommand.Dispose ();
			
		}
		
		dbCommand = null;
		
		if (reader != null) {
			
			reader.Dispose ();
			
		}
		
		reader = null;
		
		if (dbConnection != null) {
			
			dbConnection.Close ();
			
		}
		
		dbConnection = null;
		
		Debug.Log ("Disconnected from db.");
		
	}
	
	public SqliteDataReader ExecuteQuery (string sqlQuery)
		
	{
		
		dbCommand = dbConnection.CreateCommand ();
		
		dbCommand.CommandText = sqlQuery;
		
		reader = dbCommand.ExecuteReader ();
		
		return reader;
		
	}
	
	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];
		}
		Debug.Log(query);
		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];
			
		}
		if (col.Length == 0) {
			query += " FROM " + tableName;
		} else 
		{
			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);
		
	}
}

public class DataCenter{

	private string databaseFilename = "data.db";

	private string databaseFilePath;

	private DbAccess dbaccess;

	public DataCenter()
	{
		databaseFilePath = Application.persistentDataPath+"//"+databaseFilename;

		if (!File.Exists (databaseFilePath)) 
		{
			TextAsset txt = Resources.Load ("data", typeof(TextAsset))as TextAsset;

			File.WriteAllBytes(databaseFilePath,txt.bytes);

			//copy data file to sandbox
		}
		
		dbaccess = new DbAccess (@"Data Source=" + databaseFilePath);
	}
}

 


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved