Ну, это зависит. Как часто будут обновляться эти данные запроса? Если он действительно не меняется, то onApplicationStart () - это отличное место для его размещения. Однако, если он будет меняться очень часто, вы можете просто указать Coldfusion кэшировать запрос на определенный период времени , тогда вам не нужно связываться с onApplicationStart () , а скорее, когда вы вызываете запрос, он автоматически возвращает кэшированный результат (в течение указанного вами периода времени).
В любом случае, я бы написал пользовательскую функцию для извлечения данных. Тогда будет тривиально вызвать его из onApplicationStart () или из другого места.
Startup.cfc: (назван как угодно)
<!--- Replace the datasource name with your db name --->
<cffunction name="getStartupQuery" hint="Returns a query recordset for startup">
<cfargument name="datasource" required="no" type="string" default="OtherAppDB">
<!--- Init the query variable --->
<cfset var result = queryNew("id")>
<!-- Get the query dataset --->
<cfquery name="result" datasource="#arguments.datasource#">
YOUR QUERY HERE
</cfquery>
<cfreturn result>
</cffunction>
Application.cfc: (только важные части)
<cffunction name="onApplicationStart">
<!--- init the startup.cfc, then retrieve the data
and save it to the application scope. Remember the component name must match
your component above --->
<cfset var startup = createObject("component", "startup")>
<cfset application.varFromOtherDB = startup.getStartupQuery()>
<cfreturn true>
</cffunction>
Теперь вы сможете получить доступ к этой переменной из любого CFM или CFC в вашем приложении, используя:
<cfset myNewVar = application.varFromOtherDB>
or
#application.varFromOtherDB#
Если вы используете метод onApplicationStart (), я настоятельно рекомендую реализовать метод для повторного запуска приложения. Например, см. Это другое обсуждение .