SQL 调优顾问中的绑定日期

Posted

技术标签:

【中文标题】SQL 调优顾问中的绑定日期【英文标题】:Bind Dates in SQL Tuning advisor 【发布时间】:2018-08-23 14:32:11 【问题描述】:

我正在尝试使用 Oracle SQL Developers SQL Tuning advisor 将日期绑定到变量,但它会将其识别为 VARCHAR2 而不是 DATE。有没有办法指定你绑定的参数的数据类型?

SQL:

SELECT * FROM Actv
WHERE ActvId = :in_UserGrpCds AND ActvTime >= :in_FromDate AND ActvTime < :in_ThruDate
OFFSET :in_CurrRecordOffset FETCH NEXT :in_NextRecordOffset ROWS ONLY;

in_ThruDate 绑定为VARCHAR2,它无法运行。

Bind Variables :
 1 -  (NUMBER):1091
 2 -  (NUMBER):0
 3 -  (VARCHAR2):07-21-2018
 4 -  (NUMBER):50000
 5 -  (VARCHAR2):08-21-2018

-------------------------------------------------------------------------------
ERRORS SECTION
-------------------------------------------------------------------------------
- ORA-00932: inconsistent datatypes: expected DATE got NUMBER

-------------------------------------------------------------------------------

【问题讨论】:

【参考方案1】:

我们只绑定字符串/数字/空值,因此请调整您的 SQL 以包含 to_date:

SELECT * FROM Actv
WHERE ActvId = :in_UserGrpCds 
AND ActvTime >= to_date(:in_FromDate ,'MM-DD-YYYY')
AND ActvTime < to_date(:in_ThruDate ,'MM-DD-YYYY')
OFFSET :in_CurrRecordOffset FETCH NEXT :in_NextRecordOffset ROWS ONLY;

【讨论】:

以上是关于SQL 调优顾问中的绑定日期的主要内容,如果未能解决你的问题,请参考以下文章

oracle 中热门查询的自动 SQL 调优顾问报告

SQL 探查器和调优顾问

通过段调优顾问帮助解决行链接问题

通过段调优顾问回收大表的分配空间和高水位线

Oracle调整顾问(SQL Tuning Advisor 与 SQL Access Advisor

SQL Developer SQL Tuning Advisor 并非所有变量都绑定