『功能项目』Unity连接读取本地数据库【28】
打开上一篇27账号登陆注册界面UI搭建的项目,
本章要做的事情是本地数据库的连接与读取数据库中的道具信息(刀、铁块)
访问官方网站:MySQL
一、下载Mysql
首页滑到最下面,选择Downloads下的MySQL Community server
点击查看下载历史版本
下载完毕后将文件解压到你想保存到的盘和目录内。我是将文件解压到E:Program FilesMysql目录下面。
以上就完成了下载的全部工作。
二、配置环境变量
1.配置系统变量
点击新建,变量名为:MYSQL_HOME,添加你的mysql-5.7.27-winx64文件夹所在位置。
我的是在E:Program FilesMysqlmysql-5.7.27-winx64,如图:
2.编辑Path
复制**;%MYSQL_HOME%in**到原有值的后面,如图:
3.配置my.ini文件
在你的mysql-5.7.27-winx64目录下新建my.ini文件,我的是在E:Program FilesMysqlmysql-5.7.27-winx64目录下新建,
my.ini文件的内容为:如果安装目录不一样,记得修改MySQL的安装路径。
[mysqld]
#端口号
port = 3306
#mysql-5.7.27-winx64的路径
basedir=E:Program FilesMysqlmysql-5.7.27-winx64
#mysql-5.7.27-winx64的路径+data
datadir=E:Program FilesMysqlmysql-5.7.27-winx64data
#最大连接数
max_connections=200
#编码
character-set-server=utf8
default-storage-engine=INNODB
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
[mysql]
#编码
default-character-set=utf8
4.安装Mysql
(1)在输入框内输入cmd,以管理员的身份运行,注意这里一定一定一定要以管理员的身份运行,否则在安装过程中会出现因为管理权限不够而导致的Install/Remove of the Service Denied!(安装/卸载服务被拒绝),这一点非常重要!
(2)在cmd中进入到E:Program FilesMysqlmysql-5.7.27-winx64in目录下:
输入安装命令:mysqld -install,若出现Service successfully installed,证明安装成功;如出现Install of the Service Denied,则说明没有以管理员权限来运行cmd:
然后继续输入命令:mysqld --initialize,此时不会有任何提示:
再输入启动命令:net start mysql,出现以下提示证明MySQL启动成功:
5.设置Mysql密码
(1)在这里设置密码主要是为了解决:**ERROR 1045 (28000): Access denied for user ‘root’@‘localhost’ (using password: NO)**的问题
(2)首先停止MySQL服务,输入命令行 net stop mysql:
(3)在E:Program FilesMysqlmysql-5.7.27-winx64目录下找到my.ini,在[mysqld]字段下任意一行添加skip-grant-tables,保存即可:如果安装目录不一样,记得修改MySQL的安装路径。
(4)重启MySQL,输入启动命令:net start mysql,出现以下提示证明MySQL启动成功:
在输入命令mysql -u root -p,不需要输入密码,直接回车:
进入MySQL成功
(5) 输入命令行use mysql,进入数据库:
(6)输入命令行update user set authentication_string=password(“xxxxxx”) where user=“root”;
xxxxxx是你设置的新密码,敲击回车后若出现以下信息,证明修改成功 最后面的分号不要忘记
(7) 手动停止MySQL服务,在win10搜索栏内输入服务,找到MySQL。点击右键,然后点击停止即可。
然后在刚刚的my.ini文件中删除skip-grant-tables这一行,保存关闭。
(8) 再次启动cmd(管理员身份),输入启动命令:net start mysql,再输入mysql -u root -p,再输入你刚刚设置的密码,出现以下信息证明设置成功!
然后输入命令行use mysql验证一下,结果报错:
既然没有重置密码,就重置
键入命令行alter user user() identified by “xxxxxx”;
我的密码是123456,因此我键入 alter user user() identified by “123456”;回车
再次输入命令行use mysql验证一下,成功
【注意】
Nacivat和Mysql的关系就是衣服和人的关系,
没有衣服(Navicat)有人(Mysql)可以运行;
有衣服(Navicat)没人(Mysql)不能运行。
为了使用方便可以安装Navicat(方便创建数据库,表及道具信息)
安装永久版Navicat链接如下:
『云数据库』Navicat完整版破解【03】-CSDN博客
注意这里的用户名root和密码123456是通过命令设置的,如果想更改需要通过命令更改,本地数据库名不想更改的话用这个就行
打开连接变成绿色后,新建一个数据库
创建一个表
点击保存
打开表
添加道具信息
回到Unity编辑场景
新建脚本:ConnectMySql.cs
编写脚本:
using MySql.Data.MySqlClient;
using UnityEngine;
public class ConnectMySql : MonoBehaviour{
void Start(){
//数据库地址、端口、用户名、数据库名、密码
string sqlSer = "server = 127.0.0.1;port = 3306;user= root;database = database;password =123456;charset=utf8";
//建立连接
MySqlConnection conn = new MySqlConnection(sqlSer);
try{
conn.Open();
Debug.Log("------链接成功------");
//sql语句
string sqlQuary = "SELECT * FROM item;";
Debug.Log(sqlQuary);
MySqlCommand comd = new MySqlCommand(sqlQuary, conn);
MySqlDataReader reader = comd.ExecuteReader();
while (reader.Read()){
//通过reader获得数据库信息
Debug.Log(reader.GetString("name"));
}
}
catch (System.Exception e){
Debug.Log("Error:" + e.Message);
}
finally{
conn.Close();
}
}
}
将脚本挂载至空物体上
运行项目 - 本地数据库连接成功
本篇做了本地数据库的连接与读取数据库中的道具信息(刀、铁块),接下来还需做以下内容:
1.C#本地数据库账号登录与注册进入游戏
2.可拖动UI窗口
3.怪物集目标点巡航功能
4.隐藏怪物的生成
5.怪物I攻击范围内的主动攻击
6.掉落坐骑蛋的获取
7.异步传送转换场景
以及开放回合制、坐骑系统、宠物系统、背包系统、神炼系统、商城系统、Boss的目标跟随任务导航系统以及UI播放3D动画效果等等。
具体项目运行效果请关注water1024的b站视频项目演示《破碎纪元》
【Unity回合2.5D】破碎纪元_单机游戏热门视频 (bilibili.com)https://www.bilibili.com/video/BV1rZY4e9Ebs/?spm_id_from=333.999.0.0&vd_source=547091a95b03acfa8e8a9e46ef499cd6