【Unity 3D】C#从mysql数据库中读取、封装SQL语句(附源码)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 【Unity 3D】C#从mysql数据库中读取、封装SQL语句(附源码)

数据库是按照数据结构组织、存储和管理数据的仓库,是一个长期存储在计算机内的,有组织的,可共享的,统一管理的大量数据的集合

数据库分为关系型数据库和非关系型数据库。关系型数据库是把复杂的数据结构归结为简单的二元关系,对数据的操作建立在一个或多个关系表格上,通过对这些关联的表格分类,合并,连接或者选取等运算实现数据库的管理,关系型数据库的代表产品有Oracle和Mysql

非关系型数据库严格来讲不是一种数据库,是一种数据结构化存储方法的集合,可以是文档或者键值对等等,常见的非关系型数据库的类型有文档型数据库、键值对型数据库,列式数据库和图形数据库,非关系型数据库的出现主要是为了解决超大规模和高并发访问时出现的响应过慢的额外难题,非关系型数据库由于自身的特点,可以在特定场景下发挥出难以想象的高效率和高性能,是对传统关系型数据库的一个有效补充

下面是新建SqlAccess类封装SQL语句实例代码

using System;
using System.Data;
using MySql.Data.MySqlClient;
public class SqlAccess
{
    //mysql连接对象
    public static MySqlConnection dbConnection;
    //默认构造函数
    public SqlAccess(string connectionString)
    {
        OpenSql(connectionString);
    }
    //打开数据库
    public void OpenSql(string connectionString)
    {
        try
        {
            dbConnection = new MySqlConnection(connectionString);
            dbConnection.Open();
        }
        catch (Exception e)
        {
            throw new Exception("服务器连接失败 " + e.Message.ToString());
        }
    }
    //关闭数据库
    public void CloseSql()
    {
        if (dbConnection != null)
        {
            dbConnection.Close();
            dbConnection.Dispose();
            dbConnection = null;
        }
    }
    /// <summary>
    /// 执行方法
    /// </summary>
    /// <param name="sqlString">SQL命令</param>
    /// <returns></returns>
    public DataSet ExecuteQuery(string sqlString)
    {
        if (dbConnection.State == ConnectionState.Open)
        {
            //表的集合
            DataSet ds = new DataSet();
            try
            {
                MySqlDataAdapter da = new MySqlDataAdapter(sqlString, dbConnection);
                da.Fill(ds);
            }
            catch (Exception e)
            {
                throw new Exception("SQL:" + sqlString + "/n" + e.Message.ToString());
            }
            return ds;
        }
        return null;
    }
    /// <summary>
    /// 根据条件进行查询
    /// </summary>
    /// <param name="tableName">表名</param>
    /// <param name="tb_name">查询的列名</param>
    /// <param name="tb_password">查询的列名</param>
    /// <param name="name">查询的具体参数 名字</param>
    /// <param name="password">查询的具体参数 密码</param>
    /// <returns></returns>
    public DataSet SelectInto(string tableName, string tb_name, string tb_password, string name, string password)
    {
        string query = "SELECT * FROM " + tableName + " WHERE " + tb_name + "=" + "'" + name + "' " + "AND " + tb_password + "=" + "'" + password + "'";
        return ExecuteQuery(query);
    }
}

然后在Unity 3D中新建Login.cs脚本,调用SqlAccess类中封装的函数读取MySQL数据库的操作

代码如下

using System.Data;
using UnityEngine;
using UnityEngine.UI;
public class Login : MonoBehaviour
{
    //数据库对象
    public SqlAccess sql;
    //输入信息
    public InputField inputName;
    public InputField inputPassword;
    //按钮登录
    public Button btnLogin;
    //提示信息
    public Text tipText;
    // Use this for initialization
    void Start()
    {
        //MySQL数据参数设置
        string connectionString = "Server = localhost;port = 3306;Database = user;User ID = root;Password = 123456";
        //调用SqlAccess类的构造函数进行初始化
        sql = new SqlAccess(connectionString);
        //登录按钮的绑定响应事件
        btnLogin.onClick.AddListener(LoginID);
    }
    public void LoginID()
    {
        //输入参数 “表名 列名 列名 数据 数据”
        DataSet ds = sql.SelectInto("user", "uName", "uPwd", inputName.text, inputPassword.text);
        Debug.Log("检索到:" + ds.Tables[0].Rows.Count + " 条数据");
        if (ds.Tables[0].Rows.Count > 0)
        {
            Debug.Log("登陆成功");
            tipText.text = "登陆成功";
        }
        else
        {
            Debug.Log("登录失败");
            tipText.text = "登录失败";
        }
    }
}

创作不易 觉得有帮助请点赞关注收藏~~~

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
SQL 关系型数据库 MySQL
mysql 简单的sql语句,入门级增删改查
介绍MySQL中的基本SQL语句,包括数据的增删改查操作,使用示例和简单的数据表进行演示。
mysql 简单的sql语句,入门级增删改查
|
1月前
|
SQL 关系型数据库 MySQL
|
1月前
|
SQL 运维 关系型数据库
MySQL 运维 SQL 备忘
MySQL 运维 SQL 备忘录
46 1
|
2月前
|
存储 SQL 关系型数据库
【MySQL调优】如何进行MySQL调优?从参数、数据建模、索引、SQL语句等方向,三万字详细解读MySQL的性能优化方案(2024版)
MySQL调优主要分为三个步骤:监控报警、排查慢SQL、MySQL调优。 排查慢SQL:开启慢查询日志 、找出最慢的几条SQL、分析查询计划 。 MySQL调优: 基础优化:缓存优化、硬件优化、参数优化、定期清理垃圾、使用合适的存储引擎、读写分离、分库分表; 表设计优化:数据类型优化、冷热数据分表等。 索引优化:考虑索引失效的11个场景、遵循索引设计原则、连接查询优化、排序优化、深分页查询优化、覆盖索引、索引下推、用普通索引等。 SQL优化。
542 15
【MySQL调优】如何进行MySQL调优?从参数、数据建模、索引、SQL语句等方向,三万字详细解读MySQL的性能优化方案(2024版)
|
1月前
|
SQL 存储 关系型数据库
SQL文件导入MySQL数据库的详细指南
数据库中的数据转移是一项常规任务,无论是在数据迁移过程中,还是在数据备份、还原场景中,导入导出SQL文件显得尤为重要。特别是在使用MySQL数据库时,如何将SQL文件导入数据库是一项基本技能。本文将详细介绍如何将SQL文件导入MySQL数据库,并提供一个清晰、完整的步骤指南。这篇文章的内容字数大约在
156 1
|
21天前
|
SQL 关系型数据库 MySQL
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
33 0
|
21天前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
30 0
|
1月前
|
存储 SQL 关系型数据库
MySQL查询数据库锁表的SQL语句
MySQL查询数据库锁表的SQL语句
83 1
|
1月前
|
SQL 存储 关系型数据库
mysql 数据库空间统计sql
mysql 数据库空间统计sql
45 0
|
1月前
|
SQL 存储 关系型数据库
mysql SQL必知语法
本文详细介绍了MySQLSQL的基本语法,包括SELECT、FROM、WHERE、GROUPBY、HAVING、ORDERBY等关键字的使用,以及数据库操作如创建、删除表,数据类型,插入、查询、过滤、排序、连接和汇总数据的方法。通过学习这些内容,读者将能更好地管理和操
14 0