冰冰冰冰冰糖Er 2022-05-23 19:39 采纳率: 90.9%
浏览 14
已结题

向数据库导入文本数据报该字符串未被识为datatime有效值,从索引[0]处开始,但我确实进行数据转换了

问题遇到的现象和发生背景

已经将数据转换成datatime类型了,但还是报错

img

问题相关代码,请勿粘贴截图

using (SqlConnection con = new SqlConnection(conStr))
{

                con.Open();
                using (SqlCommand cmd = conn.CreateCommand())
                {
                   // string r =reader.CurrentEncoding.ToString();
                     //MessageBox.Show("当前编码格式为:{0}",r);
                    while (!string.IsNullOrEmpty(temp = reader.ReadLine()))
                  {
                       var strs = temp.Split(',');
                        string sql = string.Format(@"
                 insert into tblStudent
                 (stuName,stuSex,stuBirthDate,stuPhone)
                 values('{0}','{1}','{2}','{3}')", strs[1], strs[2], Convert.ToDateTime(strs[3]), strs[4]);
                        cmd.CommandText = sql;//不要strs[0],因为那是主键Id列,sql会自动处理
                        cmd.ExecuteNonQuery();
                    }
                }
            }
运行结果及报错内容

附上导入的数据

img

我的解答思路和尝试过的方法

经过数据转换应该是没问题了,但还是说索引[0]处有问题

我想要达到的结果

请问该怎么解决?

  • 写回答

1条回答 默认 最新

  • bekote 2022-05-23 21:57
    关注

    你的第一行是

    img


    吗,是的话要去掉这一行

    DateTimeFormatInfo dtFormat = new System.GlobalizationDateTimeFormatInfo();
    dtFormat.ShortDatePattern = "yyyy/MM/dd";
    Convert.ToDateTime(strs[3])改为Convert.ToDateTime(strs[3], dtFormat);

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 6月1日
  • 已采纳回答 5月24日
  • 创建了问题 5月23日

悬赏问题

  • ¥15 根据以下文字信息,做EA模型图
  • ¥15 删除虚拟显示器驱动 删除所有 Xorg 配置文件 删除显示器缓存文件 重启系统 可是依旧无法退出虚拟显示器
  • ¥15 vscode程序一直报同样的错,如何解决?
  • ¥15 关于使用unity中遇到的问题
  • ¥15 开放世界如何写线性关卡的用例(类似原神)
  • ¥15 关于并联谐振电磁感应加热
  • ¥60 请查询全国几个煤炭大省近十年的煤炭铁路及公路的货物周转量
  • ¥15 请帮我看看我这道c语言题到底漏了哪种情况吧!
  • ¥60 关机时蓝屏并显示KMODE_EXCEPTION_NOT_HANDLED,怎么修?
  • ¥66 如何制作支付宝扫码跳转到发红包界面