1

我希望从自定义框架迁移到 Coldbox。

该应用程序有 3 个数据源

  1. 常见的
  2. 地点

核心数据源存储有关站点的信息,通用数据源存储共享信息,如状态表,站点数据源存储与网站相关的数据。

根据请求的 URL,每个请求都会更改站点数据源,从而允许每个站点被沙箱化到自己的数据库中。

从我的测试看来,由 Coldbox 生成并在其自动装配中使用的 DatasourceBeans 似乎存储/缓存在应用程序范围内。这是我想要做的,但是对数据源的更改会在请求中持续存在。

在 Coldbox.cfc 中

datasources = {
    Core   = {name="DSNCore", dbType="mssql", username="", password=""},
    Common   = {name="DSNCommon", dbType="mssql", username="", password=""},
    Site = {name="", dbType="mssql", username="", password=""}
};

interceptors = [{
    class="interceptors.Website",
    properties={}
}];

名为 Website.cfc 的拦截器

<cfcomponent name="Website" output="false" autowire="true">

    <cfproperty name="dsncore" inject="coldbox:datasource:Core">
    <cfproperty name="dsn" inject="coldbox:datasource:Site">

    <cffunction name="Configure" access="public" returntype="void" output="false" >
    </cffunction>

    <cffunction name="preProcess" access="public" returntype="void" output="false" >
        <cfargument name="event" required="true" type="coldbox.system.web.context.RequestContext">
        <cfargument name="interceptData" required="true" type="struct">
        <cfset var q="" />

        <cfdump var="#dsn.getMemento()#" label="DSN before change" />
        <cfquery name="q" datasource="#dsncore.getName()#">
            SELECT
                Datasource
            FROM
                Websites
            WHERE
                Domain = <cfqueryparam cfsqltype="cf_sql_idstamp" value="#cgi.http_host#" />
        </cfquery>
        <cfscript>
        dsn.setName(q.Datasource);
        </cfscript>
        <cfdump var="#dsn.getMemento()#" label="DSN after change" />
        <cfdump var="#q#" label="Results of query" /><cfabort />

    </cffunction>
</cfcomponent>

有什么方法可以使用 Coldbox 自动装配数据源 bean 吗?

老实说,这正是我认为我会这样做的方式,如果有人对如何让我的模型根据请求使用非硬编码的不同数据源有任何其他想法,我很想更好地理解框架。

这个问题也延伸到 ORM。有没有办法让 Transfer 为每个请求使用不同的数据源?如果数据库可能有不同的模式怎么办?假设一个数据库已更新到较新版本,但另一个仍在使用旧版本,并且我在代码中基本上有一些 if 语句来为更新的数据库提供增强的功能。

您可能正在阅读这些问题,并自言自语“您不应该那样做”。好吧,我是,所以请不要回答说不这样做。如果您对将单个代码库附加到不同数据库的更好方法有想法,那么我会全力以赴。

4

1 回答 1

1

另一种方法是使用 Coldbox.cfc 中的 requestStartHandler

<!---config/Coldbox.cfc--->
requestStartHandler = "Main.onRequestStart"

<!---handlers/Main.cfc--->
<cffunction name="onRequestStart" returntype="void" output="false">
    <cfargument name="event" required="true">
    <cfquery name="q" datasource="#dsncore.getName()#">
        SELECT
            Datasource
        FROM
            Websites
        WHERE
            Domain = <cfqueryparam cfsqltype="cf_sql_idstamp" value="#cgi.http_host#" />
    </cfquery>

    <cfset rc.dataSource = q.Datasource />
</cffunction>

然后您只需将数据源存储在请求集合中,因为 onRequestStart 将在每个请求上触发。

于 2011-12-21T17:11:12.867 回答