【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
相关文章
|
7天前
|
SQL 缓存 监控
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
本文详细解析了数据库、缓存、异步处理和Web性能优化四大策略,系统性能优化必知必备,大厂面试高频。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
|
8天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第8天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统准备、配置安装源、安装 SQL Server 软件包、运行安装程序、初始化数据库以及配置远程连接。通过这些步骤,您可以顺利地在 CentOS 系统上部署和使用 SQL Server 2019。
|
9天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第7天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统要求检查与准备、配置安装源、安装 SQL Server 2019、配置 SQL Server 以及数据库初始化(可选)。通过这些步骤,你可以成功安装并初步配置 SQL Server 2019,进行简单的数据库操作。
|
16天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
49 3
|
16天前
|
PHP 数据库 数据安全/隐私保护
布谷直播源码部署服务器关于数据库配置的详细说明
布谷直播系统源码搭建部署时数据库配置明细!
|
19天前
|
SQL 数据采集 监控
局域网监控电脑屏幕软件:PL/SQL 实现的数据库关联监控
在当今网络环境中,基于PL/SQL的局域网监控系统对于企业和机构的信息安全至关重要。该系统包括屏幕数据采集、数据处理与分析、数据库关联与存储三个核心模块,能够提供全面而准确的监控信息,帮助管理者有效监督局域网内的电脑使用情况。
16 2
|
6月前
|
开发框架 前端开发 .NET
C#编程与Web开发
【4月更文挑战第21天】本文探讨了C#在Web开发中的应用,包括使用ASP.NET框架、MVC模式、Web API和Entity Framework。C#作为.NET框架的主要语言,结合这些工具,能创建动态、高效的Web应用。实际案例涉及企业级应用、电子商务和社交媒体平台。尽管面临竞争和挑战,但C#在Web开发领域的前景将持续拓展。
192 3
|
6月前
|
SQL 开发框架 安全
C#编程与多线程处理
【4月更文挑战第21天】探索C#多线程处理,提升程序性能与响应性。了解C#中的Thread、Task类及Async/Await关键字,掌握线程同步与安全,实践并发计算、网络服务及UI优化。跟随未来发展趋势,利用C#打造高效应用。
199 3
|
15天前
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
29 3
|
1月前
|
安全 C# 数据安全/隐私保护
实现C#编程文件夹加锁保护
【10月更文挑战第16天】本文介绍了两种用 C# 实现文件夹保护的方法:一是通过设置文件系统权限,阻止普通用户访问;二是使用加密技术,对文件夹中的文件进行加密,防止未授权访问。提供了示例代码和使用方法,适用于不同安全需求的场景。
102 0