gpt4 book ai didi

C#,从 MySQL 数据库获取 double 值的问题

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

我有一个带有表“Products”的 MySQL 数据库。 “Products”中的一列名为“Price”,数据类型为“double”。

我需要从该列中检索值,因此我创建了一个读取器等:

MySQLCommand cmd = new MySQLCommand("SELECT Price FROM Products", connection);
MySQLDataReader reader = cmd.ExecuteReaderEx();

if (reader.HasRows == true)
{
while (reader.Read() == true)
{
price = reader["Price"]).ToString();
}
}

问题是价格未设置为预期值。如果数据库中的值为“299.95”,则价格设置为“29995.0”。

知道为什么会这样吗?可以做些什么来解决它?

最佳答案

这是因为 toString() 使用了当前的 CultureInfo!double 是由逗号还是点分隔取决于文化。

CultureInfo

另见 this Stackoverflow 问题!

如果调试它,您应该会看到,reader["Price"] 正在返回一个对象 (type=Object{double})。这里的值正确吗?我想是的,所以只需执行以下操作即可显示 double 值:

string display = double.Parse(reader["Price"], CultureInfo.InvariantCulture).ToSring(CultureInfo.CurrentCulture);
System.Diagnostics.Debug.WriteLine(display);

关于C#,从 MySQL 数据库获取 double 值的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14138013/

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