如果可能的话,如何配置ColdFusion 9的ORM以使用多个dsn ?
是否可以在会话范围而不是应用程序范围的上下文中设置数据源?
或者,在CF9中,如何配置Hibernate以使用多个dsn ?
看起来我应该更具体一些…我正在寻找一个解决方案,允许根据会话指定DSN。
情况是这样的。我们有一个自定义构建的应用程序,它使用从子域确定的多个dsn。因此,从http://abc.domain.com访问的人将使用abc DSN,而访问xyz.domain.com的人将使用xyz DSN。DSN的名称在创建会话时确定,并作为会话变量存储。
我想这样做:
//Artists.cfccomponent persistent="true" datasource="#session.dsn#"
{
property name="artistid" generator="increment";
property firstname;
property lastname;
property address;
property city;
property state;
}
//Application.cfc component output="false" {
THIS.name = "MultipleDsnORMTest";
THIS.applicationTimeout = createTimeSpan(0, 0, 0, 0);
THIS.clientManagement = false;
THIS.datasource = ""; // Leaving black ==> "No data source specified."
// Setting to cfbookclub ==> "ORM is not
// configured for the current application."
// Setting to cfartgallery works but doesn't
// demonstrate use multiple DSNs
THIS.loginStorage = "cookie";
THIS.sessionManagement = true;
THIS.sessionTimeout = createTimeSpan(0, 0, 0, 0);
THIS.ormenabled = true;
THIS.ormsettings = {};
}
随着ColdFusion 9.0.1更新的引入,您可以通过ORM使用多个数据源。每个组件一次一个。在对象中使用"datasource"属性来指定应该使用哪个数据库。
<cfcomponent displayname="firstObject" datasource="dbOne">
<cffunction>
...
</cffunction>
...
</cfcomponent>
或
component datasource = 'dbOne'{
...
}
虽然可以配置ColdFusion 9在应用程序范围内使用多个数据源和ORM,但不可能配置ColdFusion 9的ORM在会话范围内使用多个dsn。