标题:苦思冥想 不知道哪里出问题了,求各位大神支招!!
取消只看楼主
alike123
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:107
专家分:428
注 册:2014-2-10
结帖率:75%
已结贴  问题点数:50 回复次数:1 
苦思冥想 不知道哪里出问题了,求各位大神支招!!
数据库是SQL Server2000
================以下是存储过程==================
CREATE PROCEDURE proc1
@sj datetime
AS
DECLARE  @sql  NVARCHAR(1000)
set  @sql='select *  from 表1  where 时间 > '''+ @sj +''''
exec(@sql )
GO

====================在查询分析器中==================
exec proc1 '2015-01-01 00:00:01'

错误提示:
从字符串转换为 datetime 时发生语法错误。

假设相关数据:
表1:
ID    时间
1    2015-01-02 00:00:00
2    2015-01-03 00:00:00
3    2015-01-04 00:00:00
搜索更多相关主题的帖子: 数据库 字符串 where 
2015-02-06 14:26
alike123
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:107
专家分:428
注 册:2014-2-10
得分:0 
已解决
自己回答:
主要是使用了convert函数:

================以下是存储过程==================
CREATE PROCEDURE proc1
@sj varchar(20)
AS
DECLARE  @sql  NVARCHAR(1000)
set  @sql='select *  from 表1  where convert(varchar(10),时间,111) > '''+ @sj +''''
exec(@sql )
GO

====================在查询分析器中==================
exec proc1 '2015/01/01'




2015-02-06 16:31



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-441829-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.210015 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved