请教关于convert(datetime,)转换失败的问题

Netcean 2016-04-15 09:37:19

select top 11
,usercontact.ContactTime
--,convert(datetime,usercontact.ContactTime) as lxsj2
,*
from users inner join usercontact
on users.userid=usercontact.userid where
1=1
and convert(datetime,usercontact.ContactTime)>=getdate()
order by users.userid desc

这样的语句会提示从字符串向 datetime 转换时失败。错误
usercontact.ContactTime虽然是nvarchar类型,但所有的数据都类似2016-04-15这样的数据格式,
1、请问为何会报错?
2、如果把where后面的and convert(datetime,usercontact.ContactTime)>=getdate()注释,而把第三行的convert(datetime,usercontact.ContactTime) as lxsj2启用,这种情况下又不报错了。这又是为何?
谢谢
...全文
480 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
Netcean 2016-04-15
  • 打赏
  • 举报
回复
引用 1 楼 Ekun_sky 的回复:
convert(datetime,usercontact.ContactTime) 改成: cast(usercontact.ContactTime as datetime) 再试试看!
报同样的错误
习惯性蹭分 2016-04-15
  • 打赏
  • 举报
回复
可能是执行计划先执行where筛选有关, 执行以下语句,会报错,说明以下猜测成立。 select convert(datetime,usercontact.ContactTime) as lxsj2 from usercontact
Ekun_sky 2016-04-15
  • 打赏
  • 举报
回复
convert(datetime,usercontact.ContactTime) 改成: cast(usercontact.ContactTime as datetime) 再试试看!

34,588

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧