C#写一个简单上位机,读取西门子1200数据,并同步到Sql Server数据库

本文介绍了如何使用C#编写一个上位机程序,通过S7.Net库连接西门子1200 PLC,动态读取数据并利用Data.SqlClient库将数据同步到Sql Server数据库中。程序还包含了一个线程来定期读取变量,以及一个定时器记录数据采集时间。同时,展示了如何从数据库中删除选定行的数据。
摘要由CSDN通过智能技术生成

引用一下西门子plc、sql server、线程用到的命名空间:S7.Net/Data.SqlClient/Threading。

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Forms;
using Amazon.Runtime.Internal.Util;
using S7.Net;
using static System.Windows.Forms.VisualStyles.VisualStyleElement.TaskbarClock;
using MessageBox = System.Windows.Forms.MessageBox;

namespace 基于上位机的测温系统
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            CheckForIllegalCrossThreadCalls = false;

        }

        bool status = false; //定义PLC连接状态字
                             //bool bOK = true; //写数据地址只读一次标志位      
                             //Thread thRead = null; //定义读写线程名
                             //int readByteSum; //定义读字节的总数变量名
                             //int readByteStart; //定义读字节的起始字节变量名
                             //IniFile Initools = new IniFile();//定义并实例化INI文件读写类

        //定义PLC及SQL Server的连接变量
        private Plc plcSm1200 = new Plc(CpuType.S71200, "192.168.2.10", 0, 1);
        private SqlConnection sqlcon = new SqlConnection("Server=SAMS;User Id=su;Pwd=112233;DataBase=SAM");


        //窗体加载事件
        private void Form1_Load(object sender, EventArgs e)
        {
            // TODO: 这行代码将数据加载到表“sAMDataSet.Jinlv2”中。您可以根据需要移动或删除它。
            this.jinlv2TableAdapter.Fill(this.sAMDataSet.Jinlv2);

            lb3.Visible = false;
            lb4.Visible = false;
            tBx1.ReadOnly = true;
            tBx2.ReadOnly = true;
            timer1.Enabled = true;
            lb1.Show();
            sqlcon.Open();//打开SQL Server数据库

            dataGridView1.Rows[0].Selected = fals
  • 8
    点赞
  • 76
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
以下是C# WinForm中将Excel数据导入到SQL Server数据库中的步骤: 1. 需要添加对Microsoft.Office.Interop.Excel和System.Data.SqlClient的引用。 2. 建立一个Windows Form应用程序,并在表单上添加一个按钮,用于触发导入Excel数据的过程。 3. 在按钮的Click事件中编代码,打开Excel文件并读取数据。 ```csharp using Excel = Microsoft.Office.Interop.Excel; Excel.Application excelApp = new Excel.Application(); Excel.Workbook workbook = excelApp.Workbooks.Open(@"C:\example.xlsx"); Excel.Worksheet worksheet = workbook.Sheets[1]; int rowsCount = worksheet.UsedRange.Rows.Count; int columnsCount = worksheet.UsedRange.Columns.Count; for (int row = 1; row <= rowsCount; row++) { for (int col = 1; col <= columnsCount; col++) { string cellValue = (worksheet.Cells[row, col] as Excel.Range).Value.ToString(); // Do something with the cell value } } workbook.Close(); excelApp.Quit(); ``` 4. 创建一个SqlConnection对象,用于连接到SQL Server数据库。 ```csharp using System.Data.SqlClient; SqlConnection connection = new SqlConnection("Data Source=serverName;Initial Catalog=databaseName;Integrated Security=True"); connection.Open(); ``` 5. 创建一个SqlCommand对象,用于执行插入语句。 ```csharp SqlCommand command = new SqlCommand("INSERT INTO TableName (Column1, Column2) VALUES (@Value1, @Value2)", connection); command.Parameters.AddWithValue("@Value1", cellValue1); command.Parameters.AddWithValue("@Value2", cellValue2); command.ExecuteNonQuery(); ``` 6. 在循环中使用SqlCommand对象插入数据。 7. 关闭SqlConnection对象。 ```csharp connection.Close(); ``` 完成以上步骤后,您的C# WinForm应用程序就能够将Excel数据导入到SQL Server数据库中了。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Sam*青华

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值