我已经做了很多谷歌搜索,试图找到准确的语法插入或更新使用法语(加拿大)本地化的十进制值的colum。我不是以法语为母语的人,也没有使用法语校勘的经验。使用Latin_General_CI_AS查询如下所示:
INSERT INTO [dbo].[MyTable] (ID, StringField, DecimalField) VALUES (1, 'Some value', 0.5)但是当使用法语排序规则时,十进制数看起来像0,5而不是0.5,只是简单的翻译就会使Server陷入混乱。INSERT查询将类似于以下内容(尽管,这是行不通的):
INSERT INTO [dbo].[MyTable] (ID, StringField, DecimalField) VALUES (1, 'Some value', 0,5)Server认为5是未指定列的附加值。我怎么才能让这件事。是否有将数字包装起来的字符使SQL Server将其视为十进制值?
发布于 2012-09-25 08:15:51
它不是关于排序规则,而是关于使用的十进制分隔符。
您应该使用参数查询。如果您使用的是参数化命令,那么SQL数据提供程序将注意十进制分隔符。
string sqlcom = @"EXECUTE [dbo].[MyProc] @x";
SqlCommand com = new SqlCommand(sqlcom, MyConnectionX);
com.Parameters.Add("@x", SqlDbType.Decimal);
com.Parameters["@x"].Value = someValue;
com.ExecuteNonQuery();https://stackoverflow.com/questions/12571549
复制相似问题