Unity3D连接本地或局域网MySQL数据库
准备工作:
1、打开 Unity3D 安装目录,到这个路径下 Editor > Data > Mono > lib > mono > 2.0 拷贝出下图的五个动态链接库,放到 Unity3D 工程目录下 Assets/Plugins 文件夹中。这里我想重点说一下,在使用过程中这五个动态链接库需要与 Unity3D 版本匹配,也就是说你不要在 Uniyt3D 5.3 版本拷贝出来,拿去 Uniyt3D 5.4 版本中使用,这是有可能出问题的,最好是在自己的 Unity3D 安装目录下去拷贝。I18N.CJK.dll 这个链接库,如果是 PC 端连接数据库可以不需要,如果是移动端连接数据库就必须要。
2、网上下载一个 MySql.Data.dll 动态链接库,也放到 Unity3D 工程目录下 Assets/Plugins 文件夹中。
为了方便对数据库进行创建、增加、删除、修改、查询等操作,我封装了一个工具类,代码如下:
- using MySql.Data.MySqlClient;
- using System;
- using System.Data;
- public class MySqlAccess
- {
- public static MySqlConnection mySqlConnection;//连接类对象
- private static string host; //IP地址。如果只是在本地的话,写localhost就可以。
- private static string id; //用户名。
- private static string pwd; //密码。
- private static string dataBase; //数据库名称。
- /// <summary>
- /// 构造方法
- /// </summary>
- /// <param name="_host">IP地址</param>
- /// <param name="_id">用户名</param>
- /// <param name="_pwd">密码</param>
- /// <param name="_dataBase">数据库名称</param>
- public MySqlAccess(string _host, string _id, string _pwd, string _dataBase)
- {
- host = _host;
- id = _id;
- pwd = _pwd;
- dataBase = _dataBase;
- OpenSql();
- }
- /// <summary>
- /// 打开数据库
- /// </summary>
- public static void OpenSql()
- {
- try
- {
- //string.Format是将指定的 String类型的数据中的每个格式项替换为相应对象的值的文本等效项。
- string mySqlString = string.Format("Database={0};Data Source={1};User Id={2};Password={3};", dataBase, host, id, pwd, "");
- mySqlConnection = new MySqlConnection(mySqlString);
- mySqlConnection.Open();
- }
- catch (Exception e)
- {
- throw new Exception("服务器连接失败,请重新检查是否打开MySql服务。" + e.Message.ToString());
- }
- }
- /// <summary>
- /// 创建表
- /// </summary>
- /// <param name="name">表名</param>
- /// <param name="colName">属性列</param>
- /// <param name="colType">属性类型</param>
- /// <returns></returns>
- public DataSet CreateTable(string name, string[] colName, string[] colType)
- {
- if (colName.Length != colType.Length)
- {
- throw new Exception("输入不正确:" + "columns.Length != colType.Length");
- }
- string query = "CREATE TABLE " + name + "(" + colName[] + " " + colType[];
- for (int i = ; i < colName.Length; i++)
- {
- query += "," + colName[i] + " " + colType[i];
- }
- query += ")";
- return QuerySet(query);
- }
- /// <summary>
- /// 创建具有id自增的表
- /// </summary>
- /// <param name="name">表名</param>
- /// <param name="col">属性列</param>
- /// <param name="colType">属性列类型</param>
- /// <returns></returns>
- 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[] + " " + colType[] + " NOT NULL AUTO_INCREMENT";
- for (int i = ; i < col.Length; ++i)
- {
- query += ", " + col[i] + " " + colType[i];
- }
- query += ", PRIMARY KEY (" + col[] + ")" + ")";
- return QuerySet(query);
- }
- /// <summary>
- /// 插入一条数据,包括所有,不适用自动累加ID。
- /// </summary>
- /// <param name="tableName">表名</param>
- /// <param name="values">插入值</param>
- /// <returns></returns>
- public DataSet InsertInto(string tableName, string[] values)
- {
- string query = "INSERT INTO " + tableName + " VALUES (" + "'" + values[] + "'";
- for (int i = ; i < values.Length; ++i)
- {
- query += ", " + "'" + values[i] + "'";
- }
- query += ")";
- return QuerySet(query);
- }
- /// <summary>
- /// 插入部分ID
- /// </summary>
- /// <param name="tableName">表名</param>
- /// <param name="col">属性列</param>
- /// <param name="values">属性值</param>
- /// <returns></returns>
- 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[];
- for (int i = ; i < col.Length; ++i)
- {
- query += ", " + col[i];
- }
- query += ") VALUES (" + "'" + values[] + "'";
- for (int i = ; i < values.Length; ++i)
- {
- query += ", " + "'" + values[i] + "'";
- }
- query += ")";
- return QuerySet(query);
- }
- /// <summary>
- /// 查询表数据
- /// </summary>
- /// <param name="tableName">表名</param>
- /// <param name="items">需要查询的列</param>
- /// <param name="whereColName">查询的条件列</param>
- /// <param name="operation">条件操作符</param>
- /// <param name="value">条件的值</param>
- /// <returns></returns>
- public DataSet Select(string tableName, string[] items, string[] whereColName, string[] operation, string[] value)
- {
- if (whereColName.Length != operation.Length || operation.Length != value.Length)
- {
- throw new Exception("输入不正确:" + "col.Length != operation.Length != values.Length");
- }
- string query = "SELECT " + items[];
- for (int i = ; i < items.Length; i++)
- {
- query += "," + items[i];
- }
- query += " FROM " + tableName + " WHERE " + " " + whereColName[] + operation[] + " '" + value[] + "'";
- for (int i = ; i < whereColName.Length; i++)
- {
- query += " AND " + whereColName[i] + operation[i] + "' " + value[i] + "'";
- }
- return QuerySet(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[] + " = " + colsvalues[];
- for (int i = ; i < colsvalues.Length; ++i)
- {
- query += ", " + cols[i] + " =" + colsvalues[i];
- }
- query += " WHERE " + selectkey + " = " + selectvalue + " ";
- return QuerySet(query);
- }
- /// <summary>
- /// 删除表数据
- /// </summary>
- /// <param name="tableName">表名</param>
- /// <param name="cols">条件:删除列</param>
- /// <param name="colsvalues">删除该列属性值所在得行</param>
- /// <returns></returns>
- public DataSet Delete(string tableName, string[] cols, string[] colsvalues)
- {
- string query = "DELETE FROM " + tableName + " WHERE " + cols[] + " = " + colsvalues[];
- for (int i = ; i < colsvalues.Length; ++i)
- {
- query += " or " + cols[i] + " = " + colsvalues[i];
- }
- return QuerySet(query);
- }
- /// <summary>
- /// 释放
- /// </summary>
- public void Close()
- {
- if (mySqlConnection != null)
- {
- mySqlConnection.Close();
- mySqlConnection.Dispose();
- mySqlConnection = null;
- }
- }
- /// <summary>
- /// 执行Sql语句
- /// </summary>
- /// <param name="sqlString">sql语句</param>
- /// <returns></returns>
- public static DataSet QuerySet(string sqlString)
- {
- if (mySqlConnection.State == ConnectionState.Open)
- {
- DataSet ds = new DataSet();
- try
- {
- MySqlDataAdapter mySqlDataAdapter = new MySqlDataAdapter(sqlString, mySqlConnection);
- mySqlDataAdapter.Fill(ds);
- }
- catch (Exception e)
- {
- throw new Exception("SQL:" + sqlString + "/n" + e.Message.ToString());
- }
- finally
- {
- }
- return ds;
- }
- return null;
- }
- }
接下来我们就可以访问数据库了,代码如下:
- using UnityEngine;
- using System.Data;
- public class Test : MonoBehaviour
- {
- private void Start()
- {
- MySqlAccess mySql = new MySqlAccess("localhost", "root", "root", "Test");
- mySql.CreateTableAutoID("tableTest", new string[] { "id", "name", "age" }, new string[] { "int", "text", "text" });
- mySql.InsertInto("tableTest", new string[] { "name", "age" }, new string[] { "张三", "" });
- mySql.InsertInto("tableTest", new string[] { "name", "age" }, new string[] { "李四", "" });
- for (int i = ; i < ; i++)
- {
- DataSet ds = mySql.Select("tableTest", new string[] { "name", "age" }, new string[] { "id" }, new string[] { "=" }, new string[] { i.ToString() });
- if (ds != null)
- {
- DataTable table = ds.Tables[];
- foreach (DataRow row in table.Rows)
- {
- foreach (DataColumn column in table.Columns)
- {
- Debug.Log(row[column]);
- }
- }
- }
- }
- mySql.Close();
- }
- }
Unity3D连接本地或局域网MySQL数据库的更多相关文章
- (转载)Unity3D连接本地或局域网MySQL数据库
准备工作: 1.打开 Unity3D 安装目录,到这个路径下 Editor > Data > Mono > lib > mono > 2.0 拷贝出下图的五个动态链接库, ...
- PHP连接局域网MYSQL数据库的简单实例
PHP连接局域网MYSQL数据库的简单实例 [php] view plaincopy <?PHP /** * php连接mysql数据库 * by www.jbxue.com */ $conn= ...
- PHP连接局域网MYSQL数据库的实例
PHP连接局域网MYSQL数据库的例子. 代码: ?> 第一行ip对应局域网某台主机,关于局域网内mysql连接可参考我的摘抄 ...
- navicat for mysql远程连接ubuntu服务器的mysql数据库
经常玩服务器上的mysql数据库,但是基于linux操作Mysql多有不便,于是就想着使用GUI工具来远程操作mysql数据库.已经不是三次使用navicat-for-mysql了,但是每次连接远程服 ...
- C#在局域网中连接Liunx上的MySql数据库
前期准备工作: 我所用的平台是VS2010和Ubuntu 14.04.3 LTS 一.由于MySql并没有集成在VS2010中所以要先安装MySQL Connector Net 6.9.8连接工具, ...
- 本地电脑通过Navicat连接阿里云的Mysql数据库
第一步:需要设置mysql的监听地址 查看mysql的监听地址: netstat -nao 如果3306(mysql默认端口)前面是0.0.0.0,则表示端口监听没有问题,如果是127.0.0.1,则 ...
- 远程连接阿里云的mysql数据库
第一步 由于mysql版本问题 先尝试打开 sudo vim /etc/mysql/my.cnf 如空,再尝试打开 sudo vim /etc/mysql/mysql.conf.d/mysqld.cn ...
- Windows连接Linux服务器中MySQL数据库-权限配置
问题描述 在Windows系统中安装了监控MySQL数据库服务器性能的工具Spotlight on MySQL,利用Spotlight连接Linux服务器中的MySQL,进行相关配置如下: 点击& ...
- 如何将redis中的数据导入到本地MongoDB和MySQL数据库
将redis中的数据导入到本地MongoDB数据库 创建一个process_items_mongodb.py文件(文件名自定义): #!/usr/bin/env python # -*- coding ...
随机推荐
- Spring整体了解
1.spring原理 内部最核心的就是IOC了,动态注入,让一个对象的创建不用new了,可以自动的生产,这其实就是利用java里的反射,反射其实就是在运行时动态的去创建.调用对象,Spring就是 ...
- delete content on the right of cursor, Mac
delete content on the right of cursor, Mac It's not convenient to press Fn+delete to delete content ...
- swift kvc赋值
1定义模型属性的时候,如果是对象,通常都是可选的(在需要的时候创建,避免写构造函数,简化代码) 2如果是基本数据类型,不能设置成可选的(运行时获取不到属性),而且要设置初始值,否则KVC会崩溃 3使用 ...
- SpringCloud系列三:SpringSecurity 安全访问(配置安全验证、服务消费端处理、无状态 Session 配置、定义公共安全配置程序类)
1.概念:SpringSecurity 安全访问 2.具体内容 所有的 Rest 服务最终都是暴露在公网上的,也就是说如果你的 Rest 服务属于一些你自己公司的私人业务,这样的结果会直接 导致你信息 ...
- 私活利器,docker快速部署node.js应用
http://cnodejs.org/topic/53f494d9bbdaa79d519c9a4a 最近研究了几天docker的快速部署,感觉很有新意,非常轻量级和方便,打算在公司推广一下,解放运维, ...
- Python单元测试unittest【转自https://www.cnblogs.com/feng0815/p/8045850.html】
[转自https://www.cnblogs.com/feng0815/p/8045850.html] Python中有一个自带的单元测试框架是unittest模块,用它来做单元测试,它里面封装好了一 ...
- Windows导入EOS工程
[Windows导入EOS工程] 编写 EOS 智能合约时,有许多EOS提供的结构.函数.宏.文档对这些内容的描述毕竟模糊,再多的文档也比不过看实际的代码,所以还要下载EOS代码看一下. 最好有个ID ...
- Java学习笔记(二十二):打包程序
加入一个程序测试完毕,我们就可以将它打包,就可以放到服务器上运行了 找到左下角的终端 点击 输入命令: mvnw clean package -DskipTests=true clean:清除以前生成 ...
- 【Django】网页跳转的问题
这两天有个比较奇怪了问题困扰着我,就是网页跳转之后页面没有变化,虽然url已经变了,但是页面还是原来的,只是表单数据清空了 就是http://127.0.0.1:8000/signup_signin/ ...
- poj3273(二分)
题目链接:https://vjudge.net/problem/POJ-3273 题意:给定n个数,将这n个数划分成m块,问所有块最大值的最小是多少. 思路:注意到所求值最大为109,所以可以用二分来 ...