2018-04-19 第一步连接数据库

虽然说unity普遍用sqlite和mysql比较多,但是由于我第一个接触的数据库就是SqlServer,本着先入为主的想法,我查阅了一下网上相关的mysql管理类略作改动,使他可以在SqlServer里运行,下面附上代码。

using UnityEngine;
using System;
using System.Data;
using System.Collections;
using MySql.Data.MySqlClient;
using MySql.Data;
using System.IO;
using System.Data.SqlClient;

public class SqlserverManager
{
    
    static string s = @"server=127.0.0.1;database=DrugDatabase;uid=sa;pwd=123456";
  /*server是你的服务器,不用的话就用本机地址,第二个填你的数据库名称,后面是你的数据库账号密  码,默认是sa/123456*/
    static SqlConnection con = new SqlConnection(s);//数据库连接
    static SqlDataAdapter sda = null;
    static SqlCommand cmd = new SqlCommand();


    public SqlserverManager()
    {

        if (con.State == ConnectionState.Closed)//检测连接是否已经打开,如果没有就打开连接
            OpenSql();
    }


    public static void OpenSql()
    {

        try
        {
            con.Open();
        }
        catch (Exception e)
        {
            throw new Exception("服务器连接失败,请重新检查是否打开MySql服务。" + e.Message.ToString());

        }

    }

    public DataSet CreateTable(string name, string[] col, string[] colType)
    {
        if (col.Length != colType.Length)
        {

            throw new Exception("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 DataSet CreateTableAutoID(string name, string[] col, string[] colType)
    {
        if (col.Length != colType.Length)
        {

            throw new Exception("columns.Length != colType.Length");

        }

        string query = "CREATE TABLE " + name + " (" + col[0] + " " + colType[0] + " NOT NULL AUTO_INCREMENT";

        for (int i = 1; i < col.Length; ++i)
        {

            query += ", " + col[i] + " " + colType[i];

        }

        query += ", PRIMARY KEY (" + col[0] + ")" + ")";

        Debug.Log(query);

        return ExecuteQuery(query);
    }

    //插入一条数据,包括所有,不适用自动累加ID。
    public DataSet 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 += ")";

        Debug.Log(query);
        return ExecuteQuery(query);

    }

    //插入部分ID
    public DataSet InsertInto(string tableName, string[] col, string[] values)
    {

        if (col.Length != values.Length)
        {

            throw new Exception("columns.Length != colType.Length");

        }

        string query = "INSERT INTO " + tableName + " (" + col[0];
        for (int i = 1; i < col.Length; ++i)
        {

            query += ", " + col[i];

        }

        query += ") VALUES (" + "'" + values[0] + "'";
        for (int i = 1; i < values.Length; ++i)
        {

            query += ", " + "'" + values[i] + "'";

        }

        query += ")";

        Debug.Log(query);
        return ExecuteQuery(query);

    }

    /// <summary>
    /// 简单查询
    /// </summary>
    /// <param name="tableName">表名</param>
    /// <param name="items">目标列</param>
    /// <param name="col">约束</param>
    /// <param name="operation">运算符</param>
    /// <param name="values">约束结果</param>
    /// <returns></returns>
    public DataSet SelectWhere(string tableName, string[] items, string[] col, string[] operation, string[] values)
    {

        if (col.Length != operation.Length || operation.Length != values.Length)
        {

            throw new Exception("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>
    /// <param name="tableName">表名</param>
    /// <param name="items">查询目标</param>
    /// <param name="col">约束</param>
    /// <param name="operation">运算符</param>
    /// <param name="values">约束结果</param>
    /// <returns></returns>
    public DataSet SelectWhereFromN(string[] tableName, string[] items, string[] col, string[] operation, string[] values)
    {

        if (col.Length != operation.Length || operation.Length != values.Length)
        {

            throw new Exception("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[0];
        for (int i = 1; i < tableName.Length; ++i)
        {

            query += ", " + tableName[i];

        }
        query += " 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>
    /// <param name="tableName">表名</param>
    /// <param name="cols">修改前</param>
    /// <param name="colsvalues">修改后</param>
    /// <param name="selectkey">约束</param>
    /// <param name="selectvalue">约束结果</param>
    /// <returns></returns>
    public DataSet 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 DataSet 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 static void Close()
    {

        con.Close();

    }
//数据库执行部分,颇为重要******
    public static DataSet ExecuteQuery(string sqlString)
    {
        if (con.State == ConnectionState.Open)//检测通道
        {
            DataSet ds = new DataSet();
            try
            {
                sda = new SqlDataAdapter(sqlString, con);
                sda.Fill(ds);
                con.Close();//执行结束关闭通道
            }
            catch (Exception ee)
            {
                throw new Exception("SQL:" + sqlString + "/n" + ee.Message.ToString());
            }
            finally
            {
            }
            return ds;
        }
        return null;
    }


}

然后我们开始简单搭建一下ui;

image.png

如图,是一个简单的登入界面,值得一提的谁手动选择密码是否显示的部分。下面附上代码

using UnityEngine;
using System.Collections;
using UnityEngine.UI;

public class InputScript : MonoBehaviour
{

    public Toggle toggle; //ui中的toggle,拖到此处即可
    public InputField input;
    void Start()
    {
        input.contentType = InputField.ContentType.Password;
        toggle.onValueChanged.AddListener(ToggleClick);
    }
    public void ToggleClick(bool isShow)
    {
        input.contentType = isShow ? InputField.ContentType.Standard : InputField.ContentType.Password;
        input.Select();
    }
}

然后我们简单的创建一个用户表


image.png

然后我们填写登入逻辑(暂时逻辑会不太完全,我还没做错误弹窗部分)

using UnityEngine;
using System;
using System.Data;
using System.Collections;
using MySql.Data.MySqlClient;
using MySql.Data;
using System.IO;
using UnityEngine.UI;
public class LoginBtn : MonoBehaviour
{
    string Error;
    public Text id;
    public InputField password;
    public string userid;
    public int myjurisdiction;
    public GameObject work;
    public GameObject login;
    public void LoginOnClick()
    {
        try
        {

            SqlserverManager sql = new SqlserverManager();
            DataSet ds = sql.SelectWhere("UserTables", new string[] { "password" }, new string[] { "id" }, new string[] { "=" }, new string[] { id.text });
            if (ds != null)
            {
                DataTable table = ds.Tables[0];
                foreach (DataRow row in table.Rows)
                {
                    foreach (DataColumn column in table.Columns)
                    {
                        Debug.Log(row[column]);
                        if(row[column].ToString() == password.text)
                        {
                            Debug.Log("bingo");
                            //跳到工作界面
                            userid = id.text;//日后会用到
                            SqlserverManager sql1 = new SqlserverManager();
                            DataSet ds1 = sql1.SelectWhere("UserTables", new string[] { "Jurisdiction" }, new string[] { "id" }, new string[] { "=" }, new string[] { id.text });
                            if (ds1 != null)
                            {
                                DataTable table1 = ds1.Tables[0];
                                foreach (DataRow row1 in table1.Rows)
                                {
                                    foreach (DataColumn column1 in table1.Columns)
                                    {
                                        Debug.Log(row1[column1]);
                                        myjurisdiction = int.Parse(row1[column1].ToString());//日后会用到
                                    }
                                }
                            }
                            work.SetActive(true);
                            login.SetActive(false);
                        }
                        else
                        {
                            Debug.Log("密码不对");
                            //密码错了
                        }
                    }
                }
                
            }
            else
            {
                Debug.Log("账号不存在");
                //报错窗口
            }
        }
        catch (Exception e)
        {
            Error = e.Message;
        }


    }
    // Update is called once per frame
    void OnGUI()
    {
        if (Error != null)
        {
            GUILayout.Label(Error);
        }

    }
}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,056评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,842评论 2 378
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,938评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,296评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,292评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,413评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,824评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,493评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,686评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,502评论 2 318
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,553评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,281评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,820评论 3 305
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,873评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,109评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,699评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,257评论 2 341

推荐阅读更多精彩内容