Unity、C#连接MySQL数据库

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: Unity、C#连接MySQL数据库(一)C#连接Mysql数据库(二)Unity连接Mysql数据库一、MySQL创建(Navicat可视化)(一)安装完MySQL后,打开Navicat进行连接,连接名随便输入,本地的(此电脑上的)MySQL主机就为:localhost或者127.0.0.1,用户名和密码:如果是本地MySQL就为你安装时设置的用户名和密码。(二)(如果是本地MySQL)快速的创建如下表:(二)Unity连接Mysql数据库三、Unity工程的创建以及MySQL包的导入

 (一)C#连接Mysql数据库

一、MySQL创建(Navicat可视化)

image.gif编辑

(一)安装完MySQL后,打开Navicat进行连接,连接名随便输入,本地的(此电脑上的)MySQL主机就为:localhost或者127.0.0.1,用户名和密码:如果是本地MySQL就为你安装时设置的用户名和密码。

(二)(如果是本地MySQL)快速的创建如下表:

image.gif编辑

image.gif编辑

二、Visual Studio 2019工程的创建

image.gif编辑

image.gif编辑

image.gif编辑

(一)创建控制台应用

(二)项目工程右键鼠标,点击管理NuGet程序包

(三)下载MySqlDate包

四、测试程序

注意:server=127.0.0.1;User Id=用户名;password=密码;Database=数据库;charset=utf8 (这里的用户名和密码都是你MySQL中的)

server=127.0.0.1;User Id=root;password=admin;Database=scores;charset=utf8 中的server如果为本机为localhost或者127.0.0.1(但是博主server=localhost程序出现了错误,所以建议用地址127.0.0.1)

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using MySql.Data.MySqlClient;
namespace ConsoleApp1
{
    class Program
    {
        //建立连接
        public static MySqlConnection mycon;
        static void Main(string[] args)
        {
            string constr = "server=127.0.0.1;User Id=root;password=admin;Database=scores;charset=utf8";
            //建立连接
            mycon = new MySqlConnection(constr);
            //打开连接
            mycon.Open();
            bool isOK = mycon.Ping();
            if (isOK)
            {
                Console.WriteLine("数据库已连接");
            }
            else
            {
                Console.WriteLine("数据库连接错误");
            }
            //查询数据
            string selstr = "select * from studentscores";
            MySqlCommand myselect = new MySqlCommand(selstr, mycon);
            DataSet ds = new DataSet();
            try
            {
                MySqlDataAdapter da = new MySqlDataAdapter(selstr, mycon);
                da.Fill(ds);
                Console.WriteLine("数据库第一行数据:\n");
                for (int i = 0; i < ds.Tables[0].Columns.Count; i++)
                {
                    Console.WriteLine(ds.Tables[0].Rows[0][i]);
                }
            }
            catch (Exception e)
            {
                throw new Exception("SQL:" + selstr + "\n" + e.Message.ToString());
            }
            //修改数据
            MySqlCommand cmd = new MySqlCommand();
            try
            {
                cmd.Connection = mycon;
                cmd.CommandText = "UPDATE studentscores SET name = @name WHERE guid = @guid";
                SqlParameter name = new SqlParameter("@name", SqlDbType.VarChar, 255);
                name.Value = "C#Test";
                SqlParameter guid = new SqlParameter("@guid", SqlDbType.VarChar, 255);
                guid.Value = "1";
                cmd.Parameters.AddWithValue("@name",name.Value.ToString());
                cmd.Parameters.AddWithValue("@guid",guid.Value.ToString());
                cmd.ExecuteNonQuery();
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
            finally
            {
                mycon.Close();
            }
            Console.ReadKey();
        }
    }
}

image.gif

结果展示:

image.gif编辑

红框就是已经修改数据的内容

(二)Unity连接Mysql数据库

一、MySQL创建(Navicat可视化)

如(一)上

二、Visual Studio 2019工程的创建

image.gif编辑

image.gif编辑

image.gif编辑

image.gif编辑

image.gif编辑

(一)创建控制台应用

(二)项目工程右键鼠标,点击管理NuGet程序包

(三)下载MySqlDate包

(四)Debug更改为Release

(五)点击生成解决方案

三、Unity工程的创建以及MySQL包的导入

image.gif编辑

(一)创建工程后创建如下文件夹(必须是Plugins)其他的随意

image.gif编辑

image.gif编辑

image.gif编辑

(二)找到(二、Visual Studio 2019工程的创建)步骤中创建的工程(我的是ConsoleApp1)

bin/Release中的所有dll文件,进行复制

image.gif编辑

(三)将所有的dll文件拖入到Plugins中

四、创建C#脚本测试数据库连接

image.gif编辑

测试代码:注意:server=127.0.0.1;User Id=用户名;password=密码;Database=数据库;charset=utf8 (这里的用户名和密码都是你MySQL中的)

server=127.0.0.1;User Id=root;password=admin;Database=scores;charset=utf8 中的server如果为本机为localhost或者127.0.0.1(但是博主server=localhost程序出现了错误,所以建议用地址)!!!!!!!!

using MySql.Data.MySqlClient;
using System;
using System.Collections;
using System.Collections.Generic;
using System.Data;
using System.Windows;
using UnityEngine;
public class TestMysql : MonoBehaviour
{
    //建立连接语句
    //charset=utf8这句要写,不然可能会报错                                 
    string constr = "server=127.0.0.1;User Id=root;password=admin;Database=scores;charset=utf8";
    //建立连接
    public static MySqlConnection mycon;
    void Start()
    {
        ConnectMysql();
        SearchMysql();
        UpadteMysql();
    }
    private void ConnectMysql()
    {
        string constr = "server=127.0.0.1;User Id=root;password=admin;Database=scores;charset=utf8";
        //建立连接
        mycon = new MySqlConnection(constr);
        //打开连接
        mycon.Open();
        bool isOK = mycon.Ping();
        if (isOK)
        {
            Debug.Log("数据库已连接");
        }
        else
        {
            Debug.Log("数据库连接错误");
        }
    }
    private void SearchMysql()
    {
        //查询数据
        string selstr = "select * from studentscores";
        MySqlCommand myselect = new MySqlCommand(selstr, mycon);
        DataSet ds = new DataSet();
        try
        {
            MySqlDataAdapter da = new MySqlDataAdapter(selstr, mycon);
            da.Fill(ds);
            Console.WriteLine("数据库第一行数据:\n");
            for (int i = 0; i < ds.Tables[0].Columns.Count; i++)
            {
                Debug.Log(ds.Tables[0].Rows[0][i]);
            }
        }
        catch (Exception e)
        {
            throw new Exception("SQL:" + selstr + "\n" + e.Message.ToString());
        }
    }
    private void UpadteMysql()
    {
        //修改数据
        MySqlCommand cmd = new MySqlCommand();
        try
        {
            cmd.Connection = mycon;
            cmd.CommandText = "UPDATE studentscores SET name = @name WHERE guid = @guid";
            Debug.Log("取出guid=1的元组,更改属性为name=C#Test");
            String name = "C#Test";
            String guid = "1";
            cmd.Parameters.AddWithValue("@name", name);
            cmd.Parameters.AddWithValue("@guid", guid);
            cmd.ExecuteNonQuery();
        }
        catch (Exception ex)
        {
            //MessageBox.Show(ex.Message);
            throw new Exception(ex.Message.ToString());
        }
        finally
        {
            mycon.Close();
        }
    }
}

image.gif

五、结果展示

image.gif编辑

image.gif编辑

将脚本拖到MainCamera上,点击运行,和控制台输出以及数据库的更改一致!

再次强调注意:server=127.0.0.1;User Id=用户名;password=密码;Database=数据库;charset=utf8 (这里的用户名和密码都是你MySQL中的)

server=127.0.0.1;User Id=root;password=admin;Database=scores;charset=utf8 中的server如果为本机为localhost或者127.0.0.1(但是博主server=localhost程序出现了错误,所以建议用地址)!!!!!!!!localhost出错概率很大,数据库连接不上时一定将localhost更改成127.0.0.1再次尝试!

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
5月前
|
SQL Java 关系型数据库
Java连接MySQL数据库环境设置指南
请注意,在实际部署时应该避免将敏感信息(如用户名和密码)硬编码在源码文件里面;应该使用配置文件或者环境变量等更为安全可靠地方式管理这些信息。此外,在处理大量数据时考虑使用PreparedStatement而不是Statement可以提高性能并防止SQL注入攻击;同时也要注意正确处理异常情况,并且确保所有打开过得资源都被正确关闭释放掉以防止内存泄漏等问题发生。
220 13
|
5月前
|
SQL 关系型数据库 MySQL
MySQL数据库连接过多(Too many connections)错误处理策略
综上所述,“Too many connections”错误处理策略涉及从具体参数配置到代码层面再到系统与架构设计全方位考量与改进。每项措施都需根据具体环境进行定制化调整,并且在执行任何变更前建议先行测试评估可能带来影响。
1419 11
|
11月前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
|
10月前
|
安全 Linux 网络安全
YashanDB数据库服务端SSL连接配置
YashanDB支持通过SSL连接确保数据传输安全,需在服务端生成根证书、服务器证书及DH文件,并将根证书提供给客户端以完成身份验证。服务端配置包括使用OpenSSL工具生成证书、设置SSL参数并重启数据库;客户端则需下载根证书并正确配置环境变量与`yasc_env.ini`文件。注意:启用SSL后,所有客户端必须持有根证书才能连接,且SSL与密码认证独立运行。
|
7月前
|
SQL XML Java
配置Spring框架以连接SQL Server数据库
最后,需要集成Spring配置到应用中,这通常在 `main`方法或者Spring Boot的应用配置类中通过加载XML配置或使用注解来实现。
581 0
|
10月前
|
Oracle 安全 关系型数据库
【Oracle】使用Navicat Premium连接Oracle数据库两种方法
以上就是两种使用Navicat Premium连接Oracle数据库的方法介绍,希望对你有所帮助!
2083 28
|
10月前
|
SQL 数据库连接 数据库
在C++的QT框架中实现SQLite数据库的连接与操作
以上就是在C++的QT框架中实现SQLite数据库的连接与操作的基本步骤。这些步骤包括创建数据库连接、执行SQL命令、处理查询结果和关闭数据库连接。在实际使用中,你可能需要根据具体的需求来修改这些代码。
631 14
|
11月前
|
数据库
【YashanDB知识库】YDC连接数据库报错yasdb return code is zero
【YashanDB知识库】YDC连接数据库报错yasdb return code is zero