• Unity、C#连接MySQL数据库


    (一)C#连接Mysql数据库

     一、MySQL创建(Navicat可视化)

    bfd1f76197bd4e21b7b8dbd9bbf9a6be.jpeg

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

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

    023f1d47f7fc4848ac99e7c8da016e81.jpeg

    c3048e239c0444858d7f4023f82928f4.jpeg

     二、Visual Studio 2019工程的创建

    7cea723c7c3946c7996365040b27b5b0.jpeg

     a75b3bdbd0254e25aa5b761b128c81d3.jpeg

    564b1947b52642caaff3bd691e7bd027.jpeg

    (一)创建控制台应用

    (二)项目工程右键鼠标,点击管理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)

    1. using System;
    2. using System.Collections.Generic;
    3. using System.Data;
    4. using System.Data.SqlClient;
    5. using System.Linq;
    6. using System.Text;
    7. using System.Threading.Tasks;
    8. using System.Windows.Forms;
    9. using MySql.Data.MySqlClient;
    10. namespace ConsoleApp1
    11. {
    12. class Program
    13. {
    14. //建立连接
    15. public static MySqlConnection mycon;
    16. static void Main(string[] args)
    17. {
    18. string constr = "server=127.0.0.1;User Id=root;password=admin;Database=scores;charset=utf8";
    19. //建立连接
    20. mycon = new MySqlConnection(constr);
    21. //打开连接
    22. mycon.Open();
    23. bool isOK = mycon.Ping();
    24. if (isOK)
    25. {
    26. Console.WriteLine("数据库已连接");
    27. }
    28. else
    29. {
    30. Console.WriteLine("数据库连接错误");
    31. }
    32. //查询数据
    33. string selstr = "select * from studentscores";
    34. MySqlCommand myselect = new MySqlCommand(selstr, mycon);
    35. DataSet ds = new DataSet();
    36. try
    37. {
    38. MySqlDataAdapter da = new MySqlDataAdapter(selstr, mycon);
    39. da.Fill(ds);
    40. Console.WriteLine("数据库第一行数据:\n");
    41. for (int i = 0; i < ds.Tables[0].Columns.Count; i++)
    42. {
    43. Console.WriteLine(ds.Tables[0].Rows[0][i]);
    44. }
    45. }
    46. catch (Exception e)
    47. {
    48. throw new Exception("SQL:" + selstr + "\n" + e.Message.ToString());
    49. }
    50. //修改数据
    51. MySqlCommand cmd = new MySqlCommand();
    52. try
    53. {
    54. cmd.Connection = mycon;
    55. cmd.CommandText = "UPDATE studentscores SET name = @name WHERE guid = @guid";
    56. SqlParameter name = new SqlParameter("@name", SqlDbType.VarChar, 255);
    57. name.Value = "C#Test";
    58. SqlParameter guid = new SqlParameter("@guid", SqlDbType.VarChar, 255);
    59. guid.Value = "1";
    60. cmd.Parameters.AddWithValue("@name",name.Value.ToString());
    61. cmd.Parameters.AddWithValue("@guid",guid.Value.ToString());
    62. cmd.ExecuteNonQuery();
    63. }
    64. catch (Exception ex)
    65. {
    66. MessageBox.Show(ex.Message);
    67. }
    68. finally
    69. {
    70. mycon.Close();
    71. }
    72. Console.ReadKey();
    73. }
    74. }
    75. }

    结果展示:

    c8a7e64581aa4115a16b2c4d3d3b99f2.png

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

    (二)Unity连接Mysql数据库

     一、MySQL创建(Navicat可视化

    如(一)上

     二、Visual Studio 2019工程的创建

    7cea723c7c3946c7996365040b27b5b0.jpeg

     a75b3bdbd0254e25aa5b761b128c81d3.jpeg

    564b1947b52642caaff3bd691e7bd027.jpeg

    f22d82cbfd9a4b17a338387b8b711f36.jpeg

    3749876a868a4f01b5d7c5d783a8b244.jpeg

    (一)创建控制台应用

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

    (三)下载MySqlDate包

    (四)Debug更改为Release

    (五)点击生成解决方案

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

    afc4cf94909f46b1bb35ec0b9954da2c.png

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

    4e07493949df49eda2642ba3a506415d.png

    328626cf016344ae9202808faeca5331.png

    b900b5bfd6f8442984ff9b69364c431b.png

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

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

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

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

    a6bbe99bb97d43b5a9216ac26f514d36.png

     测试代码:注意: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程序出现了错误,所以建议用地址)!!!!!!!!

    1. using MySql.Data.MySqlClient;
    2. using System;
    3. using System.Collections;
    4. using System.Collections.Generic;
    5. using System.Data;
    6. using System.Windows;
    7. using UnityEngine;
    8. public class TestMysql : MonoBehaviour
    9. {
    10. //建立连接语句
    11. //charset=utf8这句要写,不然可能会报错
    12. string constr = "server=127.0.0.1;User Id=root;password=admin;Database=scores;charset=utf8";
    13. //建立连接
    14. public static MySqlConnection mycon;
    15. void Start()
    16. {
    17. ConnectMysql();
    18. SearchMysql();
    19. UpadteMysql();
    20. }
    21. private void ConnectMysql()
    22. {
    23. string constr = "server=127.0.0.1;User Id=root;password=admin;Database=scores;charset=utf8";
    24. //建立连接
    25. mycon = new MySqlConnection(constr);
    26. //打开连接
    27. mycon.Open();
    28. bool isOK = mycon.Ping();
    29. if (isOK)
    30. {
    31. Debug.Log("数据库已连接");
    32. }
    33. else
    34. {
    35. Debug.Log("数据库连接错误");
    36. }
    37. }
    38. private void SearchMysql()
    39. {
    40. //查询数据
    41. string selstr = "select * from studentscores";
    42. MySqlCommand myselect = new MySqlCommand(selstr, mycon);
    43. DataSet ds = new DataSet();
    44. try
    45. {
    46. MySqlDataAdapter da = new MySqlDataAdapter(selstr, mycon);
    47. da.Fill(ds);
    48. Console.WriteLine("数据库第一行数据:\n");
    49. for (int i = 0; i < ds.Tables[0].Columns.Count; i++)
    50. {
    51. Debug.Log(ds.Tables[0].Rows[0][i]);
    52. }
    53. }
    54. catch (Exception e)
    55. {
    56. throw new Exception("SQL:" + selstr + "\n" + e.Message.ToString());
    57. }
    58. }
    59. private void UpadteMysql()
    60. {
    61. //修改数据
    62. MySqlCommand cmd = new MySqlCommand();
    63. try
    64. {
    65. cmd.Connection = mycon;
    66. cmd.CommandText = "UPDATE studentscores SET name = @name WHERE guid = @guid";
    67. Debug.Log("取出guid=1的元组,更改属性为name=C#Test");
    68. String name = "C#Test";
    69. String guid = "1";
    70. cmd.Parameters.AddWithValue("@name", name);
    71. cmd.Parameters.AddWithValue("@guid", guid);
    72. cmd.ExecuteNonQuery();
    73. }
    74. catch (Exception ex)
    75. {
    76. //MessageBox.Show(ex.Message);
    77. throw new Exception(ex.Message.ToString());
    78. }
    79. finally
    80. {
    81. mycon.Close();
    82. }
    83. }
    84. }

    五、结果展示

    63b63f4d821b431aafa8c5647afa0f71.png

    071ed7e005ad4187a30a96276c97d83f.png

     将脚本拖到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再次尝试!

  • 相关阅读:
    Java.lang.Class类 getInterfaces()方法有什么功能呢?
    Linux下的进程控制
    设计模式 - 解释器模式
    【Vue3-小项目】 评论列表(简易)-- 思路与实现分析
    三城演义!第二届中国移动“梧桐杯”大数据应用创新大赛复赛完美收官
    【机器学习10】循环神经网络
    基于JavaSwing开发餐厅点餐系统(购物,购物车,订单) 课程设计 大作业源码 毕业设计
    RabbitMQ 学习(一)---- 安装与基本配置
    第二章 论文的书写
    javascript中的事件总结
  • 原文地址:https://blog.csdn.net/weixin_48388330/article/details/126683557