首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过参数添加( C# ) (SqlDbType.DateTime),数据转换在SqlDbType.DateTime中失败

通过参数添加( C# ) (SqlDbType.DateTime),数据转换在SqlDbType.DateTime中失败
EN

Stack Overflow用户
提问于 2022-05-22 04:43:54
回答 1查看 71关注 0票数 -1

我是C#的新手。我有这样的说法失败了:

代码语言:javascript
复制
dbCmd.Parameters.Add("@createdTime", SqlDbType.DateTime);

在createdTime中的值是: 1/18/2012 11:54:11 AM经过大量故障排除后我能够缩小问题范围。如果我将值更改为: 2012-01-18 11:54:01 AM,它就会工作。所以它不适用于这种格式。我发现了这个问题,但如何解决这个问题呢?我的意思是,DateTime格式就是它的样子。

下面是我需要解释的更多代码:

代码语言:javascript
复制
        dbCmd.CommandType = CommandType.Text;
        dbCmd.CommandText = sqlCmd;
        
        dbCmd.Parameters.Add("@ID", SqlDbType.Int);
        dbCmd.Parameters.Add("@FullName", SqlDbType.NVarChar);
        dbCmd.Parameters.Add("@createdTime", SqlDbType.DateTime);
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-05-22 06:54:23

在C#中显式解析值,以便db参数包含一个DateTime,而不是字符串:

代码语言:javascript
复制
dbCmd.Parameters.Add("@createdTime", SqlDbType.DateTime)
  .Value = DateTime.ParseExact(theVariableHoldingStringDateTime, "M/d/yyyy hh:mm:ss tt", CultureInfo.InvariantCulture);

如果您使用Add,那么只需要设置一个参数,然后在循环中为其赋值:

代码语言:javascript
复制
for each line in text file parser blah blah

  dbCmd.Parameters["@createdTime"]
    .Value = DateTime.ParseExact(theVariableHoldingStringDateTime, "M/d/yyyy hh:mm:ss tt", CultureInfo.InvariantCulture);
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72334855

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档