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

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS Agent(兼容OpenClaw),2核4GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 【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 = "登录失败";
        }
    }
}

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

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
8月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
514 158
|
8月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
8月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1281 152
|
8月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
954 156
|
8月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(中)
使用MYSQL Report分析数据库性能
537 156
|
8月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(上)
最终建议:当前系统是完美的读密集型负载模型,优化重点应放在减少行读取量和提高数据定位效率。通过索引优化、分区策略和内存缓存,预期可降低30%的CPU负载,同时保持100%的缓冲池命中率。建议每百万次查询后刷新统计信息以持续优化
649 161
|
9月前
|
存储 运维 关系型数据库
从MySQL到云数据库,数据库迁移真的有必要吗?
本文探讨了企业在业务增长背景下,是否应从 MySQL 迁移至云数据库的决策问题。分析了 MySQL 的优势与瓶颈,对比了云数据库在存储计算分离、自动化运维、多负载支持等方面的优势,并提出判断迁移必要性的五个关键问题及实施路径,帮助企业理性决策并落地迁移方案。
|
8月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
8月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
8月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。

推荐镜像

更多