Heim > Datenbank > MySQL-Tutorial > Hauptteil

Access日期字段参数化查询的怪问题!

WBOY
Freigeben: 2016-06-07 15:43:37
Original
1026 人浏览过

先看一下示例的SQL语句: select ID from (select *,(select top 1 订购 日期 from 订单 where ...) as 最近订购 from 客户) where 最近订购 between @p1 and @p2 对应的添加 参数 的代码(使用Enterprise Library 3.1): db.AddInParameter(cmd, p1, DbTyp

先看一下示例的SQL语句:

select ID from (select *,(select top 1 订购日期 from 订单 where ...) as 最近订购 from 客户)  where 最近订购 between @p1 and @p2

对应的添加参数的代码(使用Enterprise Library 3.1):

db.AddInParameter(cmd, p1, DbType.DateTime, dt1);

db.AddInParameter(cmd, p2, DbType.DateTime, dt2);

为了便于阅读,我简化了语句的写法,各位请别管语法问题,我这儿要描述的问题是:使用这个SQL命令来搜索记录,不会抛出异常,但搜索结果是不正确的!而如果把SQL中的参数p1、p2直接改为#2009-2-12 12:00:00#这种形式,结果就正确了!

换句话说,使用参数方式添加参数值搜索结果不正确;直接把时期值写到SQL语句中,就正确了。这是怎么回事呢?

补充说明:1、不使用子查询的话,参数查询是正确的;2、将DbType.DateTime改为DbType.Date,或者将dt1改为dt1.ToString()同样不能解决。

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!