mysql 等于运算符中的数据类型time和datetime不兼容?

fsi0uk1n  于 2023-02-21  发布在  Mysql
关注(0)|答案(3)|浏览(221)

当我试图删除基于日期、开始和结束时间的表行时,我得到了这个错误。我使用onClick函数从表行传递日期、开始和结束时间。然后我使用 AJAX 发送这些值。下面是我的代码:

<cfoutput query="qryView">
    <table>
       <tr>
           <td>#dateFormat(DateSch,"mm/dd/yyyy")#</td>
           <td>#timeFormat(Stime,"hh:mm tt")#</td>
           <td>#timeFormat(Etime,"hh:mm tt")#</td>
           <td onClick="deleteDate('#dateFormat(DateSch,"mm/dd/yyyy")#','#timeFormat(Stime,"hh:mm tt")#','#timeFormat(Etime,"hh:mm tt")#')">Delete</td>
      </tr>
   </table>
</cfoutput>

<script>
    function deleteDate(DateSch,Stime,Etime){ 
        $.ajax(
        {
            type:'POST',
            url:'/AjaxFunction.cfc?method=deleteSchedule&returnformat=json',
            data:{'DateSch':DateSch,'Stime':Stime,'Etime':Etime},
            cache:false,
            success: function(data,x,xhrobj)
            {
                var Result = $.parseJSON(data);
                if($.trim(Result.STATUS) == '200'){
                    alert('Removed!');
                }else{
                    alert(Result.message); 
                }
            }
        });
    }
</script>

下面是我的删除查询:

<cfquery name="qryDelete" datasource="test">
    Delete From Table
    Where DateS = <cfqueryparam cfsqltype="cf_sql_date" value="#arguments.DateSch#">
    and Start = <cfqueryparam cfsqltype="cf_sql_time" value="#arguments.Stime#">
    and End = <cfqueryparam cfsqltype="cf_sql_time" value="#arguments.Etime#">
</cfquery>

首先,当我试图点击按钮删除我得到了一个java脚本错误如下:

SyntaxError: missing ) after argument list    
deleteDate('74','{ts '2015-12-10 00:00:00'}','1970-01-01 08:00:00.0','1970-01-01...

然后我把dateFormat放在要传递的日期值周围,把timeFormat放在时间值周围,这样就解决了这个问题,然后我在调用 AJAX 之后得到了一个错误:

"The data types time and datetime are incompatible in the equal to operator"

我在参数中发送的值如下所示:

DateSch 
12/10/2015
Etime   
08:25 AM
Stime   
08:00 AM

我不知道为什么会出现这个错误。在cfquery中使用这些值之前,我尝试过在coldfusion中使用createDateTime函数来转换这些值,但没有帮助。有人知道如何修复这个错误/将日期时间与值进行比较吗?

lpwwtiir

lpwwtiir1#

始终发布 complete 错误消息。您发布的查询在MySQL 5.6中运行良好。因此,尽管有“MySQL”标记,但我强烈怀疑您实际上使用的是SQL Server,并且完整的错误消息实际上是这样的:

**[Macromedia][SQLServer JDBC驱动程序][SQLServer]**数据类型time和datetime在等于运算符中不兼容。

这个错误通常是由submitting "time" values as "datetime" values引起的,因为查询最终试图比较苹果和桔子,即时间和日期时间。
某些MS SQL Server驱动程序支持通过将sendTimeAsDateTime=false添加到DSN连接属性来禁用该行为。不幸的是,这似乎不适用于核心Adobe数据库驱动程序。正如您所发现的,您将需要使用强制转换或转换。但是,不要使用varchar。这将导致隐式转换,在某些情况下会导致奇怪的结果。相反,使用与操作数左侧相同的数据类型,即time

<cfquery datasource="theDatasource">
    DELETE FROM TableName
    WHERE  DateSch = <cfqueryparam cfsqltype="cf_sql_date" value="#arguments.DateSch#">
    AND   STime = CAST(<cfqueryparam cfsqltype="cf_sql_time" value="#arguments.Stime#"> AS TIME) 
    AND   ETime = CAST(<cfqueryparam cfsqltype="cf_sql_time" value="#arguments.Etime#"> AS TIME)
</cfquery>
carvr3hs

carvr3hs2#

试试这样的方法:

<cfquery name="qryDelete" datasource="test">
    Delete From Table
    Where DATEDIFF(DateS, <cfqueryparam cfsqltype="cf_sql_date" value="#arguments.DateSch#">) = 0
    and TIMEDIFF(Start, <cfqueryparam cfsqltype="cf_sql_time" value="#arguments.Stime#">) = 0
    and TIMEDIFF(End, <cfqueryparam cfsqltype="cf_sql_time" value="#arguments.Etime#">) = 0
</cfquery>

我不熟悉ColdFusion,所以我不能肯定前面的代码没有语法错误。另外,你可能需要把你的日期格式改为YYYY-MM-DD才能让MySQL满意。

i34xakig

i34xakig3#

如果您正在使用Spring MVC框架,请将“;sendTimeAsDateTime=false”添加到数据源配置示例:

<property name="url"
        value="jdbc:sqlserver://localhost:1433;databaseName=testdb;encrypt=true;trustServerCertificate=true;sendTimeAsDateTime=false" />

相关问题