当前位置: 首页 > news >正文

C#链接数据库、操作sql、选择串口

// 公共增删方法 

using MySql.Data.MySqlClient;
using System.Data;    namespace ******
{public class MySQLHelper{private MySqlConnection conn = null;private MySqlCommand comm = null;private MySqlDataReader reader = null;/// <summary>/// 构造方法里建议连接/// </summary>/// <param name="connStr"></param>public MySQLHelper(string connStr){conn = new MySqlConnection(connStr);}/// <summary>/// 发送指令/// </summary>/// <param name="sql"></param>public void CreateCommand(string sql){if (conn.State == ConnectionState.Closed){conn.Open();}comm = new MySqlCommand(sql, conn);}/// <summary>/// 增删改公共方法/// </summary>/// <returns></returns>public int commonExecute(){int res;res = comm.ExecuteNonQuery();conn.Close();return res;}/// <summary>/// 查询方法/// </summary>/// <returns></returns>public DataTable selectExecute(){DataTable dt = new DataTable();using (reader = comm.ExecuteReader(CommandBehavior.CloseConnection)){dt.Load(reader);}return dt;}}
}

//   代码中引用

using Sunny.UI;
using System.Threading;
using System.IO.Ports;
using System;
using System.Data;string connStr = "Database=db_oxygen_check;Data Source=127.0.0.1;User Id=root;Password=root;pooling=false;CharSet=utf8;port=3306;";private void SystemSettingForm_Load(object sender, EventArgs e){//  获取可用串口、将串口名称回显到页面上string[] portNames = SerialPort.GetPortNames();foreach (string portName in portNames){uiComboBox2.Items.Add(portName);}if (uiComboBox2.Items.Count > 0){uiComboBox2.SelectedIndex = 0;MySQLHelper mySQLHelper = new MySQLHelper(connStr);string sql = "select * from tb_system_settings";mySQLHelper.CreateCommand(sql);DataTable dataTable = mySQLHelper.selectExecute();if (dataTable.Rows.Count > 0){txt_plcCom.Text = dataTable.Rows[0]["plc_com"].ToString();uiComboBox2.Text = dataTable.Rows[0]["oxygen_com"].ToString();}}}

//  按钮选中串口号和地址

      private void uiButton1_Click(object sender, EventArgs e){string plcCom = txt_plcCom.Text;string oxygenCom = uiComboBox2.Text;if (plcCom.Trim().Length == 0){UIMessageBox.ShowError("请选择正确的PLC IP地址");return;}if (oxygenCom.Trim().Length == 0){UIMessageBox.ShowError("请选择正确的***串口号");return;}string sql = "update tb_system_settings set plc_com = '" + plcCom + "', oxygen_com = '" + oxygenCom + "' where id = 1";MySQLHelper mySQLHelper = new MySQLHelper(connStr);mySQLHelper.CreateCommand(sql);int res = mySQLHelper.commonExecute();if (res > 0){UIMessageBox.ShowSuccess("设置成功!");DialogResult = System.Windows.Forms.DialogResult.OK;Thread thread = new Thread(new ParameterizedThreadStart(logWrite));OperateLog op = new OperateLog();op.operateType = 2;op.adminId = LoginDataStatic.id;op.adminName = LoginDataStatic.name;op.operageDesc = "修改系统设定为:{PLC串口号: " + plcCom + ", ***串口号: " + oxygenCom + "}";op.createTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");thread.Start(op);}else{UIMessageBox.ShowError("设置失败!");DialogResult = System.Windows.Forms.DialogResult.Cancel;}}

http://www.lryc.cn/news/347912.html

相关文章:

  • 本地搭建各大直播平台录屏服务结合内网穿透工具实现远程管理录屏任务
  • macos使用yarn创建vite时出现Usage Error: The nearest package directory问题
  • 【JAVA入门】Day04 - 方法
  • 前端报错 SyntaxError: Unexpected number in JSON at position xxxx at JSON.parse
  • Mybatis进阶详细用法
  • Android 系统省电软件分析
  • 了解什么是Docker
  • ChatGPT开源的whisper音频生成字幕
  • 融知财经:期货和现货的区别是什么?哪个风险大?
  • Android Studio开发之路(十)app中使用aar以及报错记录
  • sql-行转列3(转置)
  • MATLAB | 最新版MATLAB绘图速查表来啦!!
  • web安全之登录框渗透骚姿势,新思路
  • 无人机+自组网:空地点对点无人机通信解决方案
  • android TV app适配遥控器思路,recycleview选中放大
  • python篇-cmd 执行pip命令失败,但执行pyhon命令正常
  • Redis系列-3 Redis缓存问题
  • 【数据结构】堆(Heap)
  • vue cli 自定义项目架子,vue自定义项目架子,超详细
  • flink cdc,读取datetime类型
  • Kotlin 编译器和工具链:深入解析与实践案例
  • kettle
  • Maven 自动化构建
  • Unicode字符集和UTF编码
  • echarts默认图例(横线+圈圈)
  • Shell脚本的基础和变量
  • VRRP协议-负载分担配置【分别在路由器与交换机上配置】
  • 商务分析方法与工具(十):Python的趣味快捷-公司财务数据最炫酷可视化
  • 思源笔记如何结合群晖WebDav实现云同步数据
  • Electron Forge | 跨平台实战详解(中)