C#Windows Form App CRUD未更新记录

如何解决C#Windows Form App CRUD未更新记录

我正在尝试使用C#创建一个CRUD应用程序,以跟踪项目,分配给他们的人员及其状态。我的进度很好,但是无法使用“更新”功能。每当我尝试更新记录时,都会收到我自己的错误消息,而不是“成功更新”。

有人知道是什么导致我的if语句无法正确执行吗?

using System;
using System.Windows.Forms;
using System.Data.SqlClient;
using System.Data;


namespace SFTool
{
    public partial class MainForm : Form
    {
        public MainForm()
        {
            InitializeComponent();
        }

        SqlConnection con = new SqlConnection("my connection string here");

        public int ProjectID;

        private void MainForm_Load(object sender,System.EventArgs e)
        {
            // load in sql data to the data grid view
            GetProjectsDataset();
        }

        private void GetProjectsDataset()
        {

            SqlCommand cmd = new SqlCommand("SELECT * FROM sfProjects",con);

            DataTable dt = new DataTable();

            con.Open();

            SqlDataReader sdr = cmd.ExecuteReader();
            dt.Load(sdr);
            con.Close();

            dataGridView.DataSource = dt;
        }

        private void insertButton_Click(object sender,EventArgs e)
        {
            // allow user to insert data into the database,or create new records
            if (IsValid())
            {
                SqlCommand cmd = new SqlCommand("INSERT INTO sfProjects VALUES (@Project_ID,@FirstName,@LastName,@Project_Status)",con);
                cmd.CommandType = CommandType.Text;
                cmd.Parameters.AddWithValue("@Project_ID",projectIDTextbox.Text); // maps @Project_ID to the project ID textbox
                cmd.Parameters.AddWithValue("@FirstName",firstNameTextBox.Text);
                cmd.Parameters.AddWithValue("@LastName",lastNameTextBox.Text);
                cmd.Parameters.AddWithValue("@Project_Status",projectStatusTextbox.Text);

                con.Open();
                cmd.ExecuteNonQuery();
                con.Close();
                MessageBox.Show("New record has been successfully added to the database","Saved",MessageBoxButtons.OK,MessageBoxIcon.Information);

                // now update/REFRESH the database so it shows the new record
                GetProjectsDataset();

                // reset form controls
                ResetFormControls();
            }
        }

        // data validation. (Make sure project id is never empty)
        private bool IsValid()
        {
            if (projectIDTextbox.Text == string.Empty)
            {
                MessageBox.Show("Project ID is required.","Error",MessageBoxIcon.Error);
                return false;
            }

            // else return true (it is valid)
            return true;
        }

        private void resetButton_Click(object sender,EventArgs e)
        {
            // resets,or clears,the textboxes 
            ResetFormControls();
        }

        private void ResetFormControls()
        {
            projectIDTextbox.Clear();
            firstNameTextBox.Clear();
            lastNameTextBox.Clear();
            projectStatusTextbox.Clear();

            projectIDTextbox.Focus();
        }

        private void dataGridView_CellClick(object sender,DataGridViewCellEventArgs e)
        {
            // WHen you click on a row in the data grid,the textboxes will automatically populate with that rows values

            ProjectID = Convert.ToInt32(dataGridView.Rows[0].Cells[0].Value);

            projectIDTextbox.Text = dataGridView.SelectedRows[0].Cells[0].Value.ToString();
            firstNameTextBox.Text = dataGridView.SelectedRows[0].Cells[1].Value.ToString();
            lastNameTextBox.Text = dataGridView.SelectedRows[0].Cells[2].Value.ToString();
            projectStatusTextbox.Text = dataGridView.SelectedRows[0].Cells[3].Value.ToString();
        }

        private void updateButton_Click(object sender,EventArgs e)
        {
            if (ProjectID > 0)
            {
                SqlCommand cmd = new SqlCommand("UPDATE sfProjects SET (Project_ID = @Project_ID,FirstName = @FirstName,LastName = @LastName,Project_Status = @Project_Status WHERE ProjectID = @Project_ID)",projectStatusTextbox.Text);
                cmd.Parameters.AddWithValue("@Project_ID",this.ProjectID);

                con.Open();
                cmd.ExecuteNonQuery();
                con.Close();
                MessageBox.Show("Record is successfully updated","Updated",MessageBoxIcon.Information);

                // now update/REFRESH the database so it shows the new record
                GetProjectsDataset();

                // reset form controls
                ResetFormControls();

            }
            else
            {
                MessageBox.Show("Please select a record to update",MessageBoxIcon.Error);

            }
        }
    }
}

更新:我终于明白了

                ProjectID = Convert.ToInt32(dataGridView.Rows[0].Cells[0].Value);

需要成为

                ProjectID = Convert.ToInt32(dataGridView.SelectedRows[0].Cells[0].Value);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 <select id="xxx"> SELECT di.id, di.name, di.work_type, di.updated... <where> <if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 <property name="dynamic.classpath" value="tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-