SQL C#带小数的双打

时间:2012-03-02 10:11:52

标签: c# sql double decimal

我正在尝试在已经转换的SQL更新语句中输入一个double值(请参阅代码1),以使其数字保留在逗号后面。

(1)

double.TryParse(splitline[8], NumberStyles.AllowDecimalPoint, CultureInfo.InvariantCulture, out natMB //conversion

(2)将我的值放在我的SQL语句的过程中,我将natMB放入'Verbruikgegevens',索引位置为2. 0或1表示我输入的数据是否在漫游。这是if语句的一部分,声明它是漫游或国家数据。

sqlStatementUpdate(TrafficdataID, 0,     
(Convert.ToDouble(Verbruikgegevens.Rows[intCount].ItemArray[2],   
CultureInfo.InvariantCulture))

(3)Visual Studio中的SQL语句(C#)

public void sqlStatementUpdate(long TrafficdataID, byte Roaming, double Value)
{
    SqlCommand sqlCmd = new SqlCommand();
    sqlCmd.Connection = connection2;
    sqlCmd.CommandType = CommandType.StoredProcedure;
    sqlCmd.CommandText = "SP_SCTrafficdataDetailUpdate";
    DataAccessHelper.AddParam(sqlCmd, "TDDValue", SqlDbType.Decimal, Convert.ToDecimal(Value));
    DataAccessHelper.AddParam(sqlCmd, "TrafficdataID", SqlDbType.BigInt, TrafficdataID);
    DataAccessHelper.AddParam(sqlCmd, "TDDRoaming", SqlDbType.Bit, Roaming);
    DataAccessHelper.ExecSProcDS(sqlCmd);
}

(4)DataAccesHelper

internal static class DataAccessHelper
{
    public static void AddParam(SqlCommand cmd, string columnName, SqlDbType dbType, object paramvalue)
    {
        if (paramvalue is DateTime)
        {
            if (((DateTime)paramvalue).Date == DateTime.MinValue.Date)
            {
                paramvalue = DBNull.Value;
            }

        }

        if (paramvalue == null)
        {
            paramvalue = DBNull.Value;
        }

        string param = "@" + columnName;
        if (!cmd.Parameters.Contains(param))
        {
            if (dbType == SqlDbType.VarChar || dbType == SqlDbType.NVarChar || dbType == SqlDbType.Char || dbType == SqlDbType.NChar)
                cmd.Parameters.Add(param, dbType, 4000);
            else
                cmd.Parameters.Add(param, dbType);

            cmd.Parameters[param].SourceColumn = columnName;
            cmd.Parameters[param].Value = paramvalue;
        }
    }

    public static DataSet ExecSProcDS(SqlCommand cmd)
    {
        DataSet ds = new DataSet();

        try
        {
            SqlDataAdapter da = new SqlDataAdapter();
            da.SelectCommand = cmd;
            da.Fill(ds);
        }
        catch (Exception ex)
        {
            throw (ex);
        }
        return ds;
    }

(5)SQL语句

ALTER PROCEDURE [dbo].[SP_SCTrafficdataDetailUpdate] @TDDValue decimal, @TrafficdataID bigint, @TDDRoaming bit
AS
BEGIN
UPDATE    TR_SCTrafficDataDetail
SET              TDDValue = @TDDValue
WHERE     (TDDType = 'Data') AND (TrafficDataID = @TrafficdataID) AND (TDDRoaming = @TDDRoaming)
END

问题:在将数据导入sqltable时,是否有可能继续使用double,并将逗号保留在逗号后面?现在它似乎没有那么好用......我在SQLTable中将我的值定义为小数但是

1 个答案:

答案 0 :(得分:2)

所以问题是:

  • 我有文本输入表示数字,有时使用逗号,有时使用小数分隔符的句点。如何将这些可靠地转换为数字?

答案:这与SQL数据类型无关。您需要首先编写可靠的C#代码,将数字转换为double或decimal。要么这样做 - 你应该使用与数据库匹配的任何一个。

不变文化要求将句点作为小数点,而不是逗号。如果您使用逗号作为小数点分隔符,那么您使用了错误的文化。

如果您知道数字的格式,请使用重载的Parse并直接指定格式。

如果是来自用户输入,请使用用户的文化,或者训练用户使用哪种格式。

最后,如果你有一些奇怪的格式,你可能需要编写自己的代码来使用正则表达式来规范格式。

速度问题

万行不需要几秒而不是几分钟。

我注意到你正在为每一行创建一个新的SqlCommand。每次执行此操作时,都必须转到SQL服务器并将元数据与您正在调用的存储过程进行匹配。

只需创建一次,然后通过将值设置为新行中的值来重新使用它。只是不要忘记将NULL值设置为DBNull.Value。