3

我正在使用 Propel 作为我的 Symfony 项目的 DAL。我似乎无法让我的应用程序跨两个或多个数据库工作。

这是我的 schema.yml:

db1:
  lkp_User:
    pk_User:                     { type: integer, required: true, primaryKey: true, autoIncrement: true }
    UserName:                    { type: varchar(45), required: true }
    Password:                    longvarchar
    _uniques:
      Unique:                    [ UserName ]

db2:
  tesco:
    Id:                  { type: integer, required: true, primaryKey: true, autoIncrement: true }
    Name:                { type: varchar(45), required: true }
    Description:         longvarchar

这是databases.yml:

dev:
  db1:
    param:
      classname: DebugPDO
test:
  db1:
    param:
      classname: DebugPDO
all:
  db1:
    class: sfPropelDatabase
    param:
      classname: PropelPDO
      dsn: 'mysql:dbname=bpodb;host=localhost'   #where the db is located
      username: root
      password: #pass
      encoding: utf8
      persistent: true
      pooling: true


  db2:
    class: sfPropelDatabase
    param:
      classname: PropelPDO
      dsn: 'mysql:dbname=mystore2;host=localhost'   #where the db is located
      username: root
      password: #pass
      encoding: utf8
      persistent: true
      pooling: true

当我调用时php symfony propel-build-model,只有db1生成,db2不是。

知道如何解决这个问题吗?

4

3 回答 3

6

我解决了这个问题!最重要的是您必须根据 %dbname%.schema.yml 命名您的架构。通过这种方式,Symfony 将能够将 ymls 分配给正确的数据库。

于 2009-04-09T11:43:43.423 回答
1

此外,在运行任务时,您应该指定连接,例如:

symfony propel:build-all-load --connection=my_connection

这对我有用,希望它有所帮助。

于 2009-04-20T10:44:47.250 回答
1

您还可以使用Propel::getConnection('db2')手动检索连接。

请记住,您所说的“db1”、“db2”是连接名称。您可以通过各种登录/权限(如只读等)与同一个数据库建立多个连接。

这非常适合测试目的:您可以使用相同的连接名称与不同的数据库进行操作。没有办法让你的生产数据库崩溃:)

于 2009-05-08T08:53:24.513 回答