标题:苦思冥想 不知道哪里出问题了,求各位大神支招!!
只看楼主
alike123
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:107
专家分:428
注 册:2014-2-10
结帖率:75%
已结贴  问题点数:50 回复次数:5 
苦思冥想 不知道哪里出问题了,求各位大神支招!!
数据库是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
wp231957
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:神界
等 级:版主
威 望:422
帖 子:13681
专家分:53296
注 册:2012-10-18
得分:20 
我是来接分的  祝贺

DO IT YOURSELF !
2015-02-06 16:32
firstbobo
Rank: 3Rank: 3
等 级:论坛游侠
威 望:1
帖 子:55
专家分:106
注 册:2010-1-21
得分:30 
这是一个动态执行sql;
2015-02-06 19:58
volte
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:69
帖 子:1167
专家分:1316
注 册:2004-12-19
得分:0 
搞半天,你定义的字段非时间类型

大家都是朋友,有空就来坐坐!
2015-02-11 10:59
dxhsjjbgs
Rank: 1
等 级:新手上路
帖 子:3
专家分:7
注 册:2015-3-2
得分:0 
攒经验.哈哈
2015-03-02 15:55



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




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

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