mysql - 为什么我的 cfloop 在插入第一个 id 后停止?

标签 mysql coldfusion insert

我创建了 cfloop,它会执行我在循环上方创建的查询。在循环内部,我有另一个定义值的循环,然后使用 insert 语句进行 cfquery。在尝试将记录插入数据库之前,我测试了循环,一切看起来都很好。当我尝试应用它来插入我的记录后,我的插入语句在插入我的 .这是我的代码示例:

<cfloop query="qryRecords">
    <cfloop condition="TimeStart LTE meetingLength">
        <cfset TimeEnd = dateAdd("n", arguments.meeting, TimeStart)>
        <cfquery name="addRecords" datasource="test">
            Insert Into(Date,Name,Location)
            Values(<cfqueryparam cfsqltype="cf_sql_date" value="#arguments.date#">,
                    <cfqueryparam cfsqltype="cf_sql_char" value="#Name#">,
                    <cfqueryparam cfsqltype="cf_sql_time" value="#Location#">);
        </cfquery>
        <cfset TimeStart = dateAdd("n", arguments.meeting, TimeStart)>          
    </cfloop>
</cfloop>

在我的 qryRecords 中,我有 40 多条记录,我应该插入多个时间记录。我的插入仅针对第一条记录执行此操作并停止。就像我上面提到的,我尝试使用以下代码将其输出到屏幕上:

<cfloop query="qryRecords">
    <cfloop from="#test.Stime#" to="#test.Etime#" index="i" step="#CreateTimeSpan(0,0,test.meetingLeng,0)#">
                <cfset TimeEnd = dateAdd("n", test.meetingLeng, i)>
                    <tr>
                        <td>(#ID#) #timeFormat(TimeStart, "hh:mm tt")# - #timeFormat(TimeEnd, "hh:mm tt")#</td>
                    </tr>
                <cfset TimeStart = dateAdd("n", test.meetingLeng, i)>           
            </cfloop>       
</cfloop>

测试此代码后的输出如下所示:

    (3) 08:30 AM - 08:40 AM
    (3) 08:40 AM - 08:50 AM
    (3) 08:50 AM - 09:00 AM
    (3) 09:00 AM - 09:10 AM
    (3) 09:10 AM - 09:20 AM
    (3) 09:20 AM - 09:30 AM
    (3) 09:30 AM - 09:40 AM
   *(12) 09:40 AM - 08:40 AM
    (12) 08:40 AM - 08:50 AM
    (12) 08:50 AM - 09:00 AM
    (12) 09:00 AM - 09:10 AM
    (12) 09:10 AM - 09:20 AM
    (12) 09:20 AM - 09:30 AM
    (12) 09:30 AM - 09:40 AM
   *(23) 09:40 AM - 08:40 AM
    (23) 08:40 AM - 08:50 AM
    .......... so on.

我看不出我的插入查询有什么问题,也看不出为什么在数据库中只插入一个记录序列后它就停止了。如果有人能看到我的代码中出错的地方,请告诉我。

最佳答案

如果 qryRecords 不包含 TimeStart 列,则需要在 2 个打开的 cfloop 标记(btwn <cfloop query="qryRecords"><cfloop condition="TimeStart LTE meetingLength"> )之间重置 TimeStart。另外,cfloop 条件应该将 TimeStart 与最后一个时段的开始时间(而不是 meetLength 分钟)进行比较。

关于mysql - 为什么我的 cfloop 在插入第一个 id 后停止?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34167974/

相关文章:

SQL语法(带多个外键的INSERTS)

sql - 将另一个表中选定的列插入到表中

php - 法尔康 |对于 "belongsTo",一个查询代替两个查询

coldfusion - 将 Topaz 签名字符串(十六进制)转换为图像

javascript - Coldfusion 10 Websocket - 如何获取当前订阅者列表?

ms-access - MS Access 插入不存在的地方

c# - 从具有约束的数据库中随机选择数据

mysql - Rails 查询 - 条件连接

mysql - mysql错误1442的真正原因是什么?

perl - xml-rpc with coldfusion - 如何传入参数?