我正在尝试在已经转换的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中将我的值定义为小数但是
答案 0 :(得分:2)
所以问题是:
答案:这与SQL数据类型无关。您需要首先编写可靠的C#代码,将数字转换为double或decimal。要么这样做 - 你应该使用与数据库匹配的任何一个。
不变文化要求将句点作为小数点,而不是逗号。如果您使用逗号作为小数点分隔符,那么您使用了错误的文化。
如果您知道数字的格式,请使用重载的Parse并直接指定格式。
如果是来自用户输入,请使用用户的文化,或者训练用户使用哪种格式。
最后,如果你有一些奇怪的格式,你可能需要编写自己的代码来使用正则表达式来规范格式。
速度问题
万行不需要几秒而不是几分钟。
我注意到你正在为每一行创建一个新的SqlCommand。每次执行此操作时,都必须转到SQL服务器并将元数据与您正在调用的存储过程进行匹配。
只需创建一次,然后通过将值设置为新行中的值来重新使用它。只是不要忘记将NULL值设置为DBNull.Value。