我遇到了約20-30 MB(650000行)的XML文件循環問題。在大型XML文件中循環播放
這是我的薈萃代碼:
<cffile action="READ" ile="file.xml" variable="usersRaw">
<cfset usersXML = XmlParse(usersRaw)>
<cfset advsXML = XmlSearch(usersXML, "/advs/advuser")>
<cfset users = XmlSearch(usersXML, "/advs/advuser/user")>
<cfset numUsers = ArrayLen(users)>
<cfloop index="i" from="1" to="#numUsers#">
... some selects...
... insert...
<cfset advs = annunciXml[i]["vehicle"]>
<cfset numAdvs = ArrayLen(advs)>
<cfloop index="k" from="1" to="#numAdvs#">
... insert... or ... update...
</cfloop>
</cfloop>
xml文件的結構是(是的,不太好:-)
<advs>
<advuser>
<user>
</user>
<vehicle>
<vehicle>
</advuser>
</advs>
後〜12萬行我得到一個錯誤:「內存不足」。
如何提高腳本的性能?
如何診斷哪裏存在最大內存消耗?
是coldfusion的JavaScript兼容環境? – 2011-02-14 18:43:05