4

postgresデータベースを使用したsymfony2アプリのdoctrine2に問題があります。

エラーが発生します:

SQLSTATE[3F000]: Invalid schema name: 7 ERROR: schema "main" does not exist 

問題は、私のスキーマがメインではなくメインであるということです。名前を変更すると、テーブルリレーションでも同様のことが起こります。

SQLSTATE[42P01]: Undefined table: 7 ERROR: relation "main.brand_brandid_seq" does not exist 

問題は大文字と小文字の区別であり、おそらく引用や教義の構成と関係があると思います。

実在物:

namespace MyB\Entity;

/**
 * MyB\Entity\Brand
 *
 * @orm:Table(name="Main.Brand")
 * @orm:Entity
 */
class Brand
{
    /**
     * @var integer $brandid
     *
     * @orm:Column(name="BrandId", type="integer", nullable=false)
     * @orm:Id
     * @orm:GeneratedValue(strategy="SEQUENCE")
     * @orm:SequenceGenerator(sequenceName="Main.Brand_BrandId_seq", allocationSize="1", initialValue="1")
     */
    private $brandid;

    /**
     * @var string $brandname
     *
     * @orm:Column(name="BrandName", type="string", length=32, nullable=false)
     */
    private $brandname;

    /**
     * Set name.
     *
     * @param string $name
     */
    public function setName($name) {
        $this->brandname = $name;
    }
}

スキーマ:

SET search_path = "Main", pg_catalog;

CREATE SEQUENCE "Brand_BrandId_seq"
    START WITH 2
    INCREMENT BY 1
    NO MAXVALUE
    NO MINVALUE
    CACHE 1;


SET default_tablespace = '';

SET default_with_oids = false;


CREATE TABLE "Brand" (
    "BrandId" integer DEFAULT nextval('"Brand_BrandId_seq"'::regclass) NOT NULL,
    "BrandName" character varying(32) NOT NULL
);

コントローラ:

        $reseller = new \MyB\Entity\Brand();
        $reseller->setName('Sasa');

        $em = $this->get('doctrine.orm.entity_manager');
        $em->persist($reseller);
        $em->flush();

何か案が?

4

4 に答える 4

4

これを試して

namespace MyB\Entity;

/**
 * MyB\Entity\Brand
 *
 * @orm:Table(name="""Main"".""Brand""")
 * @orm:Entity
 */
class Brand
{
    /**
     * @var integer $brandid
     *
     * @orm:Column(name="""BrandId""", type="integer", nullable=false)
     * @orm:Id
     * @orm:GeneratedValue(strategy="SEQUENCE")
     * @orm:SequenceGenerator(sequenceName="""Main"".""Brand_BrandId_seq""", allocationSize="1", initialValue="1")
     */
    private $brandid;

    /**
     * @var string $brandname
     *
     * @orm:Column(name="""BrandName""", type="string", length=32, nullable=false)
     */
    private $brandname;

    /**
     * Set name.
     *
     * @param string $name
     */
    public function setName($name) {
        $this->brandname = $name;
    }
}

postgresでは、大文字と小文字を区別するすべての単語をエスケープする必要があります。

于 2011-04-07T05:56:49.403 に答える
1

エスケープされたテーブル名を使用するときは、この「バグ」に注意してください:https ://github.com/doctrine/doctrine2/pull/615 。Doctrineは、テーブル名の最初の文字をaliasprefixとして使用するため、引用符が使用され、すべてのSQLがクラッシュします。

于 2013-12-24T11:13:08.310 に答える
0

PpSqlBundleを作成しましたが、まだ完成していませんが、試してみることができます。動作するはずです。symfonyと同じようにフォームdbを生成できます。config.ymlには次のものが必要です:

doctrine:
dbal:
    default_connection: default
    connections:
        default:
            driver:   
            dbname:   
            host:     
            user:     
            password: 
            driverClass: PgSqlBundle\Doctrine\DBAL\Driver\PDOPgSql\Driver # it's important
            logging:  

コマンドを使用する必要があります

app/console doctrine:mapping:import Yourbundlename annotation

https://github.com/mstrzele/PgSqlBundle

于 2011-04-07T06:59:27.093 に答える
0

Laravelで移行ファイルを使用している場合。Schema::tableをSchema::createに変更します。これは誰かを助けるかもしれません。

于 2015-12-02T08:56:00.360 に答える