0

好的,所以我正在尝试以逗号分隔的文件打印出表格的内容。

using (OdbcCommand com = new OdbcCommand("SELECT * FROM pie_data WHERE Pie_ID = ?", con)) {
    com.Parameters.AddWithValue("", Request.Form["pie_id"]);
    com.ExecuteNonQuery();
    using (OdbcDataReader reader = com.ExecuteReader()) {
        string finalstring = "";
        while (reader.Read()) {
            finalstring = reader.GetString(9) + ",";
            for (int i = 0; i <= 8; i = i + 1) {
                finalstring = finalstring + reader.GetString(i) + ",";
            }
        }
    }
    Response.Write(finalstring);
    noredirect = 1;
}

我的表格布局是:

CREATE TABLE `rent_data` (
`Pies` INT(10) UNSIGNED NOT NULL,
`Name` VARCHAR(85) NOT NULL,
`Email` VARCHAR(85) NOT NULL,
`Pie_Rent` DATE NOT NULL,
`Rent_To` DATE NOT NULL,
`Returned_Date` DATE NULL DEFAULT NULL,
`Place` VARCHAR(100) NOT NULL,
`Purpose` MEDIUMTEXT NOT NULL,
`Comments` MEDIUMTEXT NULL,
`Pie_ID` SMALLINT(5) UNSIGNED ZEROFILL NOT NULL,
INDEX `Pie_ID` (`Equipment_ID`)
)

我得到的错误是:

Exception Details: System.InvalidCastException: Unable to cast object of type 'System.Int64' to type 'System.String'.

在线上:

finalstring = finalstring + reader.GetString(i) + ",";
4

3 回答 3

1

正如这里所说,转换由 ODBC 驱动程序完成,如果不支持,GetString 不会转换为字符串。由于您有非字符串列,因此您将面临此问题。

使用GetValue代替 GetString,然后使用 ToString() 转换为字符串:

finalstring += reader.GetValue(i).ToString() + ",";
于 2012-06-07T16:43:26.247 回答
0

可能您正在使用GetString()获取 Int64。您应该.GetInt64改为使用该特定值

您还应该IsDBNull在调用此方法之前调用以查找空值。

http://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqldatareader_methods

于 2012-06-07T16:41:38.467 回答
0

GetString尝试将列值转换为字符串。这不适用于非文字列,并且您显然将它们放在表中(Pies是 type longPie_Rentis a DateTime)等。您必须使用其他方法来提取数据,例如:

  finalstring = finalstring + reader[i].ToString() + ",";
于 2012-06-07T16:43:11.340 回答