WPF上位机8——C#与MySQL

ADO.NET

在这里插入图片描述

数据库连接

在这里插入图片描述
在这里插入图片描述

数据插入、删除、更改

在这里插入图片描述
在这里插入图片描述

数据查询

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

带单个参数

在这里插入图片描述
在这里插入图片描述

带多个参数

在这里插入图片描述
在这里插入图片描述

      using MySql.Data.MySqlClient;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace WpfTest
{public class SqlHelper{private static string constr = ConfigurationManager.ConnectionStrings["db"].ConnectionString;/// <summary>/// 连接数据库/// </summary>/// <returns></returns>public MySqlConnection? ConnectDatabase(){MySqlConnection connection = new MySqlConnection(constr);connection.Open();if (connection != null && connection.State == System.Data.ConnectionState.Open){Console.WriteLine("数据库连接成功");}else{Console.WriteLine("数据库连接失败");}return connection;}/// <summary>/// 关闭数据库/// </summary>/// <param name="mySqlConnection"></param>public void CloseConnection(MySqlConnection mySqlConnection){if (mySqlConnection != null && mySqlConnection.State == System.Data.ConnectionState.Open){mySqlConnection.Close();mySqlConnection = null!;}}/// <summary>/// 执行数据DML(insert,update,delete)操作/// </summary>/// <param name="sql"></param>public void ExecuteUpdate(string? sql){var connection = ConnectDatabase();MySqlCommand cmd = connection!.CreateCommand();cmd.CommandText = sql;int row = cmd.ExecuteNonQuery();if (row > 0){Console.WriteLine("操作成功");}else{Console.WriteLine("操作失败");}CloseConnection(connection);}/// <summary>/// 数据查询的调用模板/// </summary>public void test(){MySqlParameter[] parameters = new MySqlParameter[]{new MySqlParameter("@height",30),new MySqlParameter("@width",50),};string sql = "select * from tb_name where height=@height and width=@width";ExecuteQuery(sql, parameters);}/// <summary>/// 数据查询/// </summary>/// <param name="sql"></param>public void ExecuteQuery(string sql, MySqlParameter[] mySqlParameters){var connection = ConnectDatabase();try{MySqlCommand mySqlCommand = new MySqlCommand(sql, connection);foreach (MySqlParameter param in mySqlParameters){mySqlCommand.Parameters.Add(param);}MySqlDataReader mySqlDataReader = mySqlCommand.ExecuteReader();while (mySqlDataReader.Read()){mySqlDataReader.GetInt32(0);     // 通过列的索引拿到数据mySqlDataReader.GetString("表字段名1");  //通过列的名称拿到数据mySqlDataReader.GetString("表字段名2");}mySqlDataReader.Close();}catch (Exception){throw;}finally{CloseConnection(connection!);}}}
}

基于特性+反射+DAO通用操作库

ORM对象关系映射

在这里插入图片描述

数据库中表映射为实体类

在这里插入图片描述
在这里插入图片描述

调用ORM框架中提供的新增方法:构建sql语句

创建枚举

在这里插入图片描述

根据枚举类型创建sql语句

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

调用

在这里插入图片描述

实体限定

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

生成参数列表

在这里插入图片描述

生成插入的所有方法

在这里插入图片描述
在这里插入图片描述

使用特性映射表名和字段名

在这里插入图片描述
在这里插入图片描述

通过特性获取真实的表名称

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

当字段名发生更改时会报错,所以给字段也添加特性

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

修改的方法

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/26775.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JVM、JRE、JDK三者之间的关系

JVM、JRE和JDK是与Java开发和运行相关的三个重要概念。 再了解三者之前让我们先来了解下java源文件的执行顺序&#xff1a; 使用编辑器或IDE(集成开发环境)编写Java源文件.即demo.java程序必须编译为字节码文件&#xff0c;javac(Java编译器)编译源文件为demo.class文件.类文…

nginx优化与防盗链

nginx优化&#xff1a; 1隐藏版本号&#xff1a; 方法一 修改配置文件方式 vim /usr/local/nginx/conf/nginx.conf http { include mime.types; default_type application/octet-stream; server_tokens off; vim /usr/local/nginx/conf/nginx.c…

Python入门自学进阶-Web框架——38、redis、rabbitmq、git

缓存数据库redis&#xff1a; NoSQL&#xff08;Not only SQL&#xff09;泛指非关系型的数据库。为了解决大规模数据集合多重数据类的挑战。 NoSQL数据库的四大分类&#xff1a; 键值&#xff08;Key-Value&#xff09;存储数据库列存储数据库文档型数据库图形&#xff08;…

【Linux 网络】网络层协议之IP协议

IP协议 IP协议所处的位置网络层要解决的问题IP协议格式分片与组装网段划分特殊的IP地址IP地址的数量限制私网IP地址和公网IP地址路由 IP协议所处的位置 IP指网际互连协议&#xff0c;Internet Protocol的缩写&#xff0c;是TCP/IP体系中的网络层协议。 网络层要解决的问题 网络…

Docker搭建zookeeper

问题背景 前言 本文参考自&#xff1a;docker-compose快速搭建Zookeeper集群还有一种更加详细更加全面的部署方式&#xff1a;Docker之docker-compose一键部署Zookeeper集群&#xff0c;但笔者还未验证&#xff0c;先记录下来 搭建 安装docker-ce 此处不赘述 安装docker-co…

javaweb监听和渲染技术

jsp入门使用 <% page import"java.io.PrintWriter" %> <%-- Created by IntelliJ IDEA.--%> <%-- User: 韩顺平--%> <%-- jsp的模板如何定制&#xff0c;一会再说明--%> <%-- To change this template use File | Settings | File T…

使用gpt对对话数据进行扩增,对话数据扩增,数据增强

我们知道一个问题可以使用很多方式问&#xff0c;但都可以使用完全一样的回答&#xff0c;基于这个思路&#xff0c;我们可以很快的扩增我们的数据集。思路就是使用chatgpt或者gpt4生成类似问题&#xff0c;如下&#xff1a; 然后我们可以工程化这个过程&#xff0c;从而快速扩…

【JAVA】数组

⭐ 作者&#xff1a;小胡_不糊涂 &#x1f331; 作者主页&#xff1a;小胡_不糊涂的个人主页 &#x1f4c0; 收录专栏&#xff1a;浅谈Java &#x1f496; 持续更文&#xff0c;关注博主少走弯路&#xff0c;谢谢大家支持 &#x1f496; 数组 1. 数组的基本概念1.1 为什么要使用…

Spring Boot整合ES的两种方式

使用Spring Data Elasticsearch Starter 在Spring Boot中整合Elasticsearch的方式之一是使用Elasticsearch的官方Spring Data Elasticsearch Starter。该Starter提供了对Elasticsearch的高级集成&#xff0c;简化了配置和管理Elasticsearch客户端。 下面是使用Spring Data E…

网关 GateWay 的使用详解、路由、过滤器、跨域配置

一、网关的基本概念 SpringCloudGateway网关是所有微服务的统一入口。 1.1 它的主要作用是&#xff1a; 反向代理&#xff08;请求的转发&#xff09; 路由和负载均衡 身份认证和权限控制 对请求限流 1.2 相比于Zuul的优势&#xff1a; SpringCloudGateway基于Spring5中…

javascript:js介绍初体验和变量以及数据类型的使用。

目录 一.介绍 1概念 2作用 3组成 二.js初体验 1.js的书写位置 a.行间引入 b.内部引入 c.外部引入​编辑 2.js的注释 3.js的结束符 4.输入输出语句 输出语法 输入语法 三.变量及数据类型 ​ 1.字面量 2.变量 ​编辑 变量的使用 ​编辑 let和var的区别…

在 Linux 上以 All-in-One 模式安装 KubeSphere

官方文档&#xff1a;https://www.kubesphere.io/zh/docs/v3.3/quick-start/all-in-one-on-linux/ 操作系统 最低配置 Ubuntu&#xff1a; 16.04,18.04, 20.04, 22.04 2 核 CPU&#xff0c;4 GB 内存&#xff0c;40 GB 磁盘空间Debian Buste&#xff1a;Stretch 2 核 CPU&am…

【严重】Smartbi商业智能BI软件权限绕过漏洞

漏洞描述 Smartbi 是一款商业智能应用&#xff0c;提供了数据集成、分析、可视化等功能&#xff0c;帮助用户理解和使用他们的数据进行决策。 在 Smartbi 受影响版本中存在权限绕过问题&#xff0c;未授权的攻击者可以通过 RMI 的方式调用 getPassword 接口获取管理员 token …

jQuery知识

DOM知识 alert(我是弹窗); prompt(弹窗输入);Dom元素节点获取 方式一&#xff1a;通过 id 获取 一个 元素节点&#xff08;为什么是一个呢&#xff1f;因为 id 是唯一的&#xff09; var div1 document.getElementById("box1"); 方式二&#xff1a;通过 标签名 获…

conda 环境 numpy 安装报错需要 Microsoft Visual C++ 14.0

到公司装深度学校环境。项目较旧&#xff0c;安装依赖&#xff0c;一堆报错&#xff08;基于 conda 环境&#xff09;&#xff1a; numpy 安装报需要 C 14.0 No module named numpy.distutils._msvccompiler in numpy.distutils; trying from distutilserror: Microsoft Visu…

预测知识 | 预测模型变量重要性、可视化及论文撰写指南

预测知识 | 预测模型变量重要性、可视化及论文撰写指南 目录 预测知识 | 预测模型变量重要性、可视化及论文撰写指南变量重要性模型可视化论文撰写指南参考资料 变量重要性 关于预测模型变量重要性&#xff0c;大家一定熟悉不过。但如下图所示&#xff0c;其展示上可有进一步优…

网络安全进阶学习第十三课——SQL注入Bypass姿势

文章目录 一、等号被过滤二、substr、mid等被过滤三、逗号被过滤四、and/or被过滤五、空格被过滤五、其他绕过方式 一、等号被过滤 1、like&#xff0c;rlike语句&#xff0c;其中rlike是正则2、大于号>&#xff0c;小于号<3、符号<>&#xff1a;<>为不等于…

飞凌OKMX6ULL-C开发板试用

开箱体验 主要配件包括&#xff1a;USB Type-C调试线、电源线、主板。 资源下载 开发环境 飞凌提供了制作好的ubuntu18.04的镜像&#xff0c;直接到网盘下载解压即可&#xff0c;VMWare的安装可以参考网上教程&#xff0c;这里不赘述。安装好VMWare后直接打开解压出来的ubu…

高性能MySQL实战(一):表结构

大家好&#xff0c;我是 方圆。最近因需求改动新增了一些数据库表&#xff0c;但是在定义表结构时&#xff0c;具体列属性的选择有些不知其所以然&#xff0c;索引的添加也有遗漏和不规范的地方&#xff0c;所以我打算为创建一个高性能表的过程以实战的形式写一个专题&#xff…

IMv1.0

一、背景内容 总结golang基础内容&#xff0c;通过一个实例实时 IM系统简进行总结知识 二、简要的图 简要说明&#xff1a; 1.在server.go中&#xff0c;创建一个Newserver返回server指针的结构体 2.正对这个指针结构体实现两个方法 Handler&#xff08;处理方法&#xff0…