『功能项目』Unity连接读取本地数据库【28】

2024-09-06 14:52

本文主要是介绍『功能项目』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=utf8default-storage-engine=INNODBsql_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)icon-default.png?t=O83Ahttps://www.bilibili.com/video/BV1rZY4e9Ebs/?spm_id_from=333.999.0.0&vd_source=547091a95b03acfa8e8a9e46ef499cd6

这篇关于『功能项目』Unity连接读取本地数据库【28】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142318

相关文章

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

golang内存对齐的项目实践

《golang内存对齐的项目实践》本文主要介绍了golang内存对齐的项目实践,内存对齐不仅有助于提高内存访问效率,还确保了与硬件接口的兼容性,是Go语言编程中不可忽视的重要优化手段,下面就来介绍一下... 目录一、结构体中的字段顺序与内存对齐二、内存对齐的原理与规则三、调整结构体字段顺序优化内存对齐四、内

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

配置springboot项目动静分离打包分离lib方式

《配置springboot项目动静分离打包分离lib方式》本文介绍了如何将SpringBoot工程中的静态资源和配置文件分离出来,以减少jar包大小,方便修改配置文件,通过在jar包同级目录创建co... 目录前言1、分离配置文件原理2、pom文件配置3、使用package命令打包4、总结前言默认情况下,

java如何通过Kerberos认证方式连接hive

《java如何通过Kerberos认证方式连接hive》该文主要介绍了如何在数据源管理功能中适配不同数据源(如MySQL、PostgreSQL和Hive),特别是如何在SpringBoot3框架下通过... 目录Java实现Kerberos认证主要方法依赖示例续期连接hive遇到的问题分析解决方式扩展思考总