在Unity中創(chuàng)建一個數(shù)據(jù)庫管理類和數(shù)據(jù)庫操作方法

這里我們使用Sqlite數(shù)據(jù)庫冰啃,Sqlite數(shù)據(jù)庫是一個輕量級伍掀、跨平臺的關(guān)系型數(shù)據(jù)庫绩脆,尤其是跨平臺更是和Unity非常的搭配萤厅,但是應(yīng)為輕量化,所以不能滿足企業(yè)級數(shù)據(jù)庫的要求靴迫,但是一些小型游戲使用的話足可以滿足需求
1.Mono.Data.Sqlite.dll
在unity安裝文件“Unity\Editor\Data\MonoBleedingEdge\lib\mono”可以找到惕味,注意mono文件夾下面 有對應(yīng)版本號,可以根據(jù)自己的項目來決定選擇玉锌。
2.System.Data.dll 同上位置一樣可以找到 名挥,不過建議使用2.0版本
3.sqlite3.dll 就在\Unity\Editor下可以找到
找到這些文件,還沒有大功告成下面我們還需要把這3個文件放在你的項目的這個路徑下面:\Assets\Plugins\主守,沒有Plugins文件夾就必須創(chuàng)建這個文件夾禀倔,然后將這三個dll文件放在該文件夾下面。Plugins是專門存放數(shù)組庫文件的文件夾参淫,命名必須一字不差救湖,不然會找不到路徑

QQ圖片20160412145549.png
QQ圖片20160412145606.png

好啦 ,環(huán)境準(zhǔn)備工作完成 下面就直接上代碼
首先是一個 Sqlite的數(shù)據(jù)庫操作類涎才,
using UnityEngine;
using System.Collections;
//導(dǎo)入sqlite數(shù)據(jù)集鞋既,也就是Plugins文件夾下的那個dll文件
using Mono.Data.Sqlite;
using System;
//數(shù)據(jù)集 是formwork2.0 用vs開發(fā)要自己引用框架中的System.Data
using System.Data;
public class SqliteDbHelper
{
/// <summary>
/// 聲明一個連接對象
/// </summary>
private SqliteConnection dbConnection;
/// <summary>
/// 聲明一個操作數(shù)據(jù)庫命令
/// </summary>
private SqliteCommand dbCommand;
/// <summary>
/// 聲明一個讀取結(jié)果集的一個或多個結(jié)果流
/// </summary>
private SqliteDataReader reader;
/// <summary>
/// 數(shù)據(jù)庫的連接字符串,用于建立與特定數(shù)據(jù)源的連接
/// </summary>
/// <param name="connectionString">數(shù)據(jù)庫的連接字符串,用于建立與特定數(shù)據(jù)源的連接</param>
public SqliteDbHelper (string connectionString)
{
OpenDB (connectionString);
Debug.Log(connectionString);
}
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);
}
}
/// <summary>
/// 關(guān)閉連接
/// </summary>
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.");
}
/// <summary>
/// 執(zhí)行查詢sqlite語句操作
/// </summary>
/// <param name="sqlQuery"></param>
/// <returns></returns>
public SqliteDataReader ExecuteQuery (string sqlQuery)
{
dbCommand = dbConnection.CreateCommand ();
dbCommand.CommandText = sqlQuery;
reader = dbCommand.ExecuteReader ();
return reader;
}
/// <summary>
/// 查詢該表所有數(shù)據(jù)
/// </summary>
/// <param name="tableName">表名</param>
/// <returns></returns>
public SqliteDataReader ReadFullTable (string tableName)
{
string query = "SELECT * FROM " + tableName;
return ExecuteQuery (query);
}
/// <summary>
/// 動態(tài)添加表字段到指定表
/// </summary>
/// <param name="tableName">表名</param>
/// <param name="values">字段集合</param>
/// <returns></returns>
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;
}
query += ")";
return ExecuteQuery (query);
}
/// <summary>
/// 動態(tài)更新表結(jié)構(gòu)
/// </summary>
/// <param name="tableName">表名</param>
/// <param name="cols">字段集</param>
/// <param name="colsvalues">對于集合值</param>
/// <param name="selectkey">要查詢的字段</param>
/// <param name="selectvalue">要查詢的字段值</param>
/// <returns></returns>
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+" ="+ colsvalues;
}
query += " WHERE "+selectkey+" = "+selectvalue+" ";
return ExecuteQuery (query);
}
/// <summary>
/// 動態(tài)刪除指定表字段數(shù)據(jù)
/// </summary>
/// <param name="tableName">表名</param>
/// <param name="cols">字段</param>
/// <param name="colsvalues">字段值</param>
/// <returns></returns>
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+" = "+ colsvalues;
}
Debug.Log(query);
return ExecuteQuery (query);
}
/// <summary>
/// 動態(tài)添加數(shù)據(jù)到指定表
/// </summary>
/// <param name="tableName">表名</param>
/// <param name="cols">字段</param>
/// <param name="values">值</param>
/// <returns></returns>
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;
}
query += ") VALUES (" + values[0];
for (int i = 1; i < values.Length; ++i)
{
query += ", " + values;
}
query += ")";
return ExecuteQuery (query);
}
/// <summary>
/// 動態(tài)刪除表
/// </summary>
/// <param name="tableName">表名</param>
/// <returns></returns>
public SqliteDataReader DeleteContents (string tableName)
{
string query = "DELETE FROM " + tableName;
return ExecuteQuery (query);
}
/// <summary>
/// 動態(tài)創(chuàng)建表
/// </summary>
/// <param name="name">表名</param>
/// <param name="col">字段</param>
/// <param name="colType">類型</param>
/// <returns></returns>
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 + " " + colType;
}
query += ")";
Debug.Log(query);
return ExecuteQuery (query);
}
/// <summary>
/// 根據(jù)查詢條件 動態(tài)查詢數(shù)據(jù)信息
/// </summary>
/// <param name="tableName">表</param>
/// <param name="items">查詢數(shù)據(jù)集合</param>
/// <param name="col">字段</param>
/// <param name="operation">操作</param>
/// <param name="values">值</param>
/// <returns></returns>
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;
}
query += " FROM " + tableName + " WHERE " + col[0] + operation[0] + "'" + values[0] + "' ";
for (int i = 1; i < col.Length; ++i)
{
query += " AND " + col + operation + "'" + values[0] + "' ";
}
return ExecuteQuery (query);
}
}
下面是數(shù)據(jù)庫的操作類
using UnityEngine;
using System.Collections;
using System;
using Mono.Data.Sqlite;
using System.Data;
public class SqliteDbTest : MonoBehaviour {

SqliteDbHelper db ;
int id=1;
void Start ()
{
        db = new SqliteDbHelper("Data Source=./sqlite.db");
        Debug.Log(db.ToString());
   /*
    SqliteDbAccess db = new SqliteDbAccess("data source=mydb1.db");
  db.CreateTable("momo",new string[]{"name","qq","email","blog"},
   new string[]{"text","text","text","text"});
  db.CloseSqlConnection();
   */
  }    public  string name = "";
        public string emls = "";
void OnGUI()
{

  if(GUILayout.Button("create table"))
  {
   db.CreateTable("mytable",new string[]{"id","name","email"},new string[]{"int","varchar(20)","varchar(50)"});
   Debug.Log("create table ok");
  }

  if(GUILayout.Button("insert data"))
  {

   db.InsertInto("mytable",
                new string[] { "" + (++id), "'隨風(fēng)去旅行"+id+"'","'zhangj_live"+id+"@163.com'"});//),"'aaa"+id+"'","'aaa"+id+"@sohu.com'"});

   Debug.Log("insert table ok");
  }


  if(GUILayout.Button("search database"))
        {
            IDataReader sqReader = db.SelectWhere("mytable", new string[]
    {"name","email"},new string[]{"id"},new string[]{"="},new string[]{"2"});
   while (sqReader.Read())
   {

     //Debug.Log(
     name= "name="+sqReader.GetString(sqReader.GetOrdinal("name"));// +
                 emls = "email=" + sqReader.GetString(sqReader.GetOrdinal("email"));
     //);
   }

  }
        if (name != "")
        {
            GUI.Label(new Rect(100, 100, 100, 100), name);
            GUI.Label(new Rect(100, 200, 100, 100), emls);
            //  GUILayout.Label(emls);
        }
  if(GUILayout.Button("close database"))
  {
   db.CloseSqlConnection();
   Debug.Log("close table ok");
  }

}

}

運(yùn)行以后

QQ圖片20160412150845.jpg

注意涛救,創(chuàng)建的Sqlite數(shù)據(jù)庫的表放在StreamingAssets文件夾下畏邢,這也是系統(tǒng)的指定路徑,用來存放數(shù)據(jù)庫的表文件

QQ圖片20160412151108.png

我使用的數(shù)據(jù)庫可視化工具是SQLiteManager检吆,在他里面創(chuàng)建表就可以了


QQ圖片20160412151407.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末舒萎,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子蹭沛,更是在濱河造成了極大的恐慌臂寝,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件摊灭,死亡現(xiàn)場離奇詭異咆贬,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)帚呼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進(jìn)店門掏缎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人煤杀,你說我怎么就攤上這事眷蜈。” “怎么了沈自?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵酌儒,是天一觀的道長。 經(jīng)常有香客問我枯途,道長忌怎,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任酪夷,我火速辦了婚禮榴啸,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘捶索。我一直安慰自己插掂,他們只是感情好灰瞻,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布腥例。 她就那樣靜靜地躺著,像睡著了一般酝润。 火紅的嫁衣襯著肌膚如雪燎竖。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天要销,我揣著相機(jī)與錄音构回,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛纤掸,可吹牛的內(nèi)容都是我干的脐供。 我是一名探鬼主播,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼借跪,長吁一口氣:“原來是場噩夢啊……” “哼政己!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起掏愁,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤歇由,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后果港,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體沦泌,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年辛掠,在試婚紗的時候發(fā)現(xiàn)自己被綠了谢谦。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,680評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡萝衩,死狀恐怖他宛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情欠气,我是刑警寧澤厅各,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站预柒,受9級特大地震影響队塘,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜宜鸯,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一憔古、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧淋袖,春花似錦鸿市、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至剥懒,卻和暖如春内舟,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背初橘。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工验游, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留充岛,地道東北人。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓耕蝉,卻偏偏與公主長得像崔梗,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子垒在,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評論 2 361

推薦閱讀更多精彩內(nèi)容