| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1266 人关注过本帖
标题:苦思冥想 不知道哪里出问题了,求各位大神支招!!
只看楼主 加入收藏
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: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册: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
快速回复:苦思冥想 不知道哪里出问题了,求各位大神支招!!
数据加载中...
 
   



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

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