注册 登录
编程论坛 SQL Server论坛

苦思冥想 不知道哪里出问题了,求各位大神支招!!

alike123 发布于 2015-02-06 14:26, 1266 次点击
数据库是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
5 回复
#2
alike1232015-02-06 16:31
已解决
自己回答:
主要是使用了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'




#3
wp2319572015-02-06 16:32
我是来接分的  祝贺
#4
firstbobo2015-02-06 19:58
这是一个动态执行sql;
#5
volte2015-02-11 10:59
搞半天,你定义的字段非时间类型
#6
dxhsjjbgs2015-03-02 15:55
攒经验.哈哈
1