gpt4 book ai didi

C# MySqlConnector 6.4.4 LAST_INSERT_ID() 作为 INT64?

转载 作者:行者123 更新时间:2023-11-29 02:33:33 25 4
gpt4 key购买 nike

SELECT CONVERT(LAST_INSERT_ID(), SIGNED INTEGER);

MySqlCommand.ExecuteScalar() 和 MySqlDataReader.GetValue(int index) 都返回 object 类型。我假设因为我明确地将 LAST_INSERT_ID 转换为 SIGNED INTEGER,所以我可以使用 (int)cmd.ExecuteScalar()(int)rdr.GetValue( 0)

但是,我不断收到一条错误消息,指出转换无效。在调试时我注意到返回的对象类型是 INT64。因此,我可以通过使用 (long)cmd.ExecuteScalar() 转换值来拆箱对象。

我只是想了解为什么它以 INT64 而不是 INT32 的形式返回?

顺便说一句,自动增量列的数据类型是 SIGNED INTEGER

这是一个测试用例:

using (MySqlConnection con = new MySqlConnection(ConfigurationManager.ConnectionStrings["skimmel"].ConnectionString))
{
using (MySqlCommand cmd = new MySqlCommand(@"INSERT INTO test (Name) VALUES (@Name); SELECT CONVERT(LAST_INSERT_ID(), SIGNED INTEGER);", con))
{
var p = new MySqlParameter("@Name", MySqlDbType.String);
p.Value = "Test" + DateTime.Now.Ticks.ToString();
cmd.Parameters.Add(p);

con.Open();

object val = cmd.ExecuteScalar();
Type t = val.GetType();
long l = (long)val;
int i1 = Convert.ToInt32(val);
int i2 = (int)val; // <-- Error here!
}
}

做了一些跟进测试,发现问题并非孤立于 LAST_INSERT_ID。 SELECT 1 AS IDSELECT CONVERT(1, SIGNED INTEGER) As ID 也通过连接器返回 64 位 int。将尝试通过在 ILSpy 中加载 MySql.Data 来查看是否可以解决任何问题

最佳答案

在发布连接器/网络错误并获得反馈后,我被定向到文档。转换为整数类型时,CONVERT 和 CAST 都会产生 64 位数字。不知道为什么他们不只是做像 CAST(1 As SMALLINT)、CAST(1 AS INT)、CAST(1 AS BIGINT) 这样的事情,但他们不这样做。由于它作为 LONGLONG(64 位)从 MySQL 服务器返回,连接器不知道它应该是 32 位 int。

我仍在尝试弄清楚为什么 LAST_INSERT_ID() 从服务器返回 LONGLONG。

关于C# MySqlConnector 6.4.4 LAST_INSERT_ID() 作为 INT64?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8934338/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com