繁体   English   中英

无法将数据集数据插入数据库表

[英]Trouble Inserting Dataset data into Database table

我用这个链接来弄清楚如何做到这一点。 但我的问题是它不起作用。 这是我的代码:

public void UpdateDatabase(DataSet data, string tableName)
{
    string connectionString = ConfigurationManager.ConnectionStrings["TestDbOnBrie"].ConnectionString;
    using (SqlConnection connection = new SqlConnection(connectionString))
    {
        try
        {
            connection.Open();
            using (SqlDataAdapter adapter = new SqlDataAdapter("SELECT * FROM dbo.TransportSchedule_Customer;", connection))
            {
                using (SqlCommand updateCmd = new SqlCommand("UPDATE dbo.TransportSchedule_Customer SET Alias=@Alias, DeliveryDays1=@DeliveryDays1, DeliveryHours1=@DeliveryHours1, DeliveryType1=@DeliveryType1, DeliveryDays2=@DeliveryDays2, DeliveryHours2=@DeliveryHours2, DeliveryType2=@DeliveryType2, DeliveryDays3=@DeliveryDays3, DeliveryHours3=@DeliveryHours3, DeliveryType3=@DeliveryType3,  DistanceToDealer=@DistanceToDealer WHERE AdrID=@AdrID AND CustID=@CustID", connection))
                {
                    updateCmd.Parameters.Add("@CustID", SqlDbType.VarChar, 50, "CustID");
                    updateCmd.Parameters.Add("@AdrID", SqlDbType.Int, 50,"AdrID");
                    updateCmd.Parameters.Add("@Alias", SqlDbType.VarChar, 50, "Alias");

                    updateCmd.Parameters.Add("@DeliveryDays1", SqlDbType.VarChar, 50, "DeliveryDays1");
                    updateCmd.Parameters.Add("@DeliveryHours1", SqlDbType.VarChar, 50, "DeliveryHours1");
                    updateCmd.Parameters.Add("@DeliveryType1", SqlDbType.VarChar, 50, "DeliveryType1");

                    updateCmd.Parameters.Add("@DeliveryDays2", SqlDbType.VarChar, 50, "DeliveryDays2");
                    updateCmd.Parameters.Add("@DeliveryHours2", SqlDbType.VarChar, 50, "DeliveryHours2");
                    updateCmd.Parameters.Add("@DeliveryType2", SqlDbType.VarChar, 50, "DeliveryType2");

                    updateCmd.Parameters.Add("@DeliveryDays3", SqlDbType.VarChar, 50, "DeliveryDays3");
                    updateCmd.Parameters.Add("@DeliveryHours3", SqlDbType.VarChar, 50, "DeliveryHours3");
                    updateCmd.Parameters.Add("@DeliveryType3", SqlDbType.VarChar, 50, "DeliveryType3");

                    updateCmd.Parameters.Add("@Alias", SqlDbType.VarChar, 50, "Alias");

                    adapter.UpdateCommand = updateCmd;
                }
            }
        }
        catch (Exception exception)
        {
            Console.WriteLine("ERROR in UpdateDatabase() method. Error Message : " + exception.Message);
        }
        finally
        {
            if (connection.State == System.Data.ConnectionState.Open)
            {
                connection.Close();
            }
        }
    }
}

代码运行没有任何错误,但我的数据库表没有使用新信息更新。 我可以看到数据集具有从Excel文件中检索的正确信息。

你忘记调用Update方法来更新你在这里可能有问题的数据

检查你给出的链接有这样的更新方法

sqlDa.Update(dSet,"emp");

哪个在数据库中更新。


MSDN

DataAdapter.Update方法 - 从名为“ Table ”的DataTable为指定DataSet中的每个inserted, updated, or deleted行调用相应的INSERT, UPDATE, or DELETE语句。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM