数据源中 String 类型的给定值无法转换为指定目标列的 int 类型

本文关键字:类型 int 目标 转换 String 数据源 | 更新日期: 2023-09-27 18:31:26

我正在尝试从xml文件中读取值,然后使用批量复制将数据插入我的数据库。

我正在使用一个自定义类,它是:

class Customer
    {
        public int CustomerID { get; set; }
        public string FirstName { get; set; }
        public string LastName { get; set; }
        public int ShowsNumber { get; set; }
        public int VisitNumber { get; set; }
        public int Cancellation { get; set; }
    }

我像这样阅读数据:

List<Customer> customersList =
                (
                    from e in XDocument.Load(file).Root.Elements("cust")
                    select new Customer
                    {
                        CustomerID = (int)e.Attribute("custid"),
                        FirstName = (string)e.Attribute("fname"),
                        LastName = (string)e.Attribute("lname"),
                        ShowsNumber = (int)e.Attribute("count_noshow"),
                        VisitNumber = (int)e.Attribute("count_resos"),
                        Cancellation = (int)e.Attribute("count_cancel"),
                    }).ToList();

然后,我将customersList插入到数据库中,如下所示:

DataTable dataTable = getBasicDataTable();
for (int i = 0; i < customersList.Count; i++)
                {
                    DataRow datarows = dataTable.NewRow();
                    datarows[0] = customersList[i].CustomerID;
                    datarows[1] = customersList[i].FirstName;
                    datarows[2] = customersList[i].LastName;
                    datarows[3] = customersList[i].ShowsNumber;
                    datarows[4] = customersList[i].VisitNumber;
                    datarows[5] = customersList[i].Cancellation;
                    dataTable.Rows.Add(datarows);
                }

然后我像这样将数据插入我的数据库:

但我得到了这个例外

using (SqlBulkCopy sbc = new SqlBulkCopy(GetConnectionString()))
            {
                sbc.DestinationTableName = XMLReader.databaseTable;
                sbc.WriteToServer(dataTable);
            }

数据源中 String 类型的给定值无法转换为指定目标列的 int 类型。

如您所见,当我从 XML 中提取数据时,我已经使用强制转换来intstring并且它正在工作。 那么为什么在插入数据库时我得到了该异常?

注意

为了给你整个代码,这是getBasicDataTable功能

private DataTable getBasicDataTable()
        {
            DataTable dataTable = new DataTable();
            dataTable.Clear();
            dataTable.Columns.Add("customerID");
            dataTable.Columns.Add("firstName");
            dataTable.Columns.Add("lastName");
            dataTable.Columns.Add("showsNumber");
            dataTable.Columns.Add("visitNumber");
            dataTable.Columns.Add("cancellation");
            return dataTable;
        }

数据源中 String 类型的给定值无法转换为指定目标列的 int 类型

您需要

在定义datatable时将列指定为整数。喜欢这个:-

dataTable.Columns.Add("customerID", typeof(int));

编辑:
我怀疑的另一个原因可能是您绑定数据表的方式(我的意思是列的顺序)与数据库表的顺序不匹配。原因是我认为默认映射不是名称到名称,而是 SqlBulkCopy 中的索引到索引。因此,请重新检查您的数据库表顺序,它应该看起来像:-

CustomerID (INT)
FirstName (VARCHAR'NVARCHAR)
LastName (VARCHAR'NVARCHAR)
ShowsNumber (INT)
VisitNumber (INT)
Cancellation (INT)

据我所知,您需要在数据表上设置列的类型,否则它将假定为字符串(因为几乎所有内容都可以这样转换)。

在设置值之前,请尝试:

dataTable.Columns[2].Type = typeof (int);

或者,您也可以在定义列时指定它:

dataTable.Columns.Add("ShowsNumber", typeof(int));