Unity、C#连接MySQL数据库

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 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再次尝试!

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
数据库 C# 开发者
ADO.NET连接到南大通用GBase 8s数据库
ADO.NET连接到南大通用GBase 8s数据库
|
2月前
|
数据库连接 Linux Shell
Linux下ODBC与 南大通用GBase 8s数据库的无缝连接配置指南
本文详细介绍在Linux系统下配置GBase 8s数据库ODBC的过程,涵盖环境变量设置、ODBC配置文件编辑及连接测试等步骤。首先配置数据库环境变量如GBASEDBTDIR、PATH等,接着修改odbcinst.ini和odbc.ini文件,指定驱动路径、数据库名称等信息,最后通过catalog.c工具或isql命令验证ODBC连接是否成功。
|
2月前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
61 3
|
2月前
|
JSON JavaScript 关系型数据库
node.js连接GBase 8a 数据库 并进行查询代码示例
node.js连接GBase 8a 数据库 并进行查询代码示例
|
2月前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
|
2月前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(下)
本文接续前文,深入讲解了在Windows环境下使用C#和ADO.NET操作南大通用GBase 8s数据库的方法。通过Visual Studio 2022创建项目,添加GBase 8s的DLL引用,并提供了详细的C#代码示例,涵盖数据库连接、表的创建与修改、数据的增删查改等操作,旨在帮助开发者提高数据库管理效率。
|
2月前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
50 1
|
2月前
|
Java 数据库连接 数据库
Java连接池在数据库性能优化中的重要作用。连接池通过预先创建和管理数据库连接,避免了频繁创建和关闭连接的开销
本文深入探讨了Java连接池在数据库性能优化中的重要作用。连接池通过预先创建和管理数据库连接,避免了频繁创建和关闭连接的开销,显著提升了系统的响应速度和吞吐量。文章介绍了连接池的工作原理,并以HikariCP为例,展示了如何在Java应用中使用连接池。通过合理配置和优化,连接池技术能够有效提升应用性能。
59 1
|
5月前
|
图形学 C#
超实用!深度解析Unity引擎,手把手教你从零开始构建精美的2D平面冒险游戏,涵盖资源导入、角色控制与动画、碰撞检测等核心技巧,打造沉浸式游戏体验完全指南
【8月更文挑战第31天】本文是 Unity 2D 游戏开发的全面指南,手把手教你从零开始构建精美的平面冒险游戏。首先,通过 Unity Hub 创建 2D 项目并导入游戏资源。接着,编写 `PlayerController` 脚本来实现角色移动,并添加动画以增强视觉效果。最后,通过 Collider 2D 组件实现碰撞检测等游戏机制。每一步均展示 Unity 在 2D 游戏开发中的强大功能。
240 6
|
5月前
|
图形学 缓存 算法
掌握这五大绝招,让您的Unity游戏瞬间加载完毕,从此告别漫长等待,大幅提升玩家首次体验的满意度与留存率!
【8月更文挑战第31天】游戏的加载时间是影响玩家初次体验的关键因素,特别是在移动设备上。本文介绍了几种常见的Unity游戏加载优化方法,包括资源的预加载与异步加载、使用AssetBundles管理动态资源、纹理和模型优化、合理利用缓存系统以及脚本优化。通过具体示例代码展示了如何实现异步加载场景,并提出了针对不同资源的优化策略。综合运用这些技术可以显著缩短加载时间,提升玩家满意度。
352 5