繁体   English   中英

SQLSTATE [42S02]:找不到基表或视图:1146表'pdone.BaseUser'不存在

[英]SQLSTATE[42S02]: Base table or view not found: 1146 Table 'pdone.BaseUser' doesn't exist

我使用的是从内FOSUserBundle的1.3.x-dev的SonataUserBundle 我已经按照UserBundle安装的每个步骤进行安装和配置。 这是我在实体中拥有的:

#src/Application/Sonata/UserBundle/Entity/User.php

namespace Application\Sonata\UserBundle\Entity;

use Sonata\UserBundle\Entity\BaseUser as BaseUser;
use Doctrine\ORM\Mapping as ORM;

class User extends BaseUser
{
    /**
     * @var int
     */
    protected $id;

    /**
     * Get id.
     *
     * @return int $id
     */
    public function getId()
    {
        return $this->id;
    }
}

#src/Application/Sonata/UserBundle/Entity/Group.php

namespace Application\Sonata\UserBundle\Entity;

use Sonata\UserBundle\Entity\BaseGroup as BaseGroup;
use Doctrine\ORM\Mapping as ORM;

class Group extends BaseGroup
{
    /**
     * @var int
     */
    protected $id;

    /**
     * Get id.
     *
     * @return int $id
     */
    public function getId()
    {
        return $this->id;
    }
}

这是配置的样子:

#FOSUserBundle
fos_user:
    db_driver: orm # other valid values are 'mongodb', 'couchdb' and 'propel'
    firewall_name: main
    user_class:     Application\Sonata\UserBundle\Entity\User

    group:
        group_class:   Application\Sonata\UserBundle\Entity\Group
        group_manager: sonata.user.orm.group_manager

    service:
        user_manager: sonata.user.orm.user_manager

    from_email:
        address:        noreply@pdi.com
        sender_name:    Mail Service

doctrine:
    dbal:
        types:
            json: Sonata\Doctrine\Types\JsonType
        default_connection:   default
        connections:
            default:
                driver:   pdo_mysql
                host:     "%database_host%"
                port:     "%database_port%"
                dbname:   "%database_name%"
                user:     "%database_user%"
                password: "%database_password%"
                charset:  UTF8

                logging: true
                profiling: true
    orm:
        auto_generate_proxy_classes: "%kernel.debug%"
        entity_managers:
          default:
            #I have tried here using mappings and without it - same issue
            mappings:
                FOSUserBundle: ~
                ApplicationSonataUserBundle: ~
                SonataUserBundle: ~
            auto_mapping: true
            filters:
                softdeleteable:
                  class: Gedmo\SoftDeleteable\Filter\SoftDeleteableFilter
                  enabled: false

这是一段AppKernel.php

...
new Sonata\CoreBundle\SonataCoreBundle(),
new Sonata\BlockBundle\SonataBlockBundle(),
new Sonata\UserBundle\SonataUserBundle('FOSUserBundle'),
new Sonata\EasyExtendsBundle\SonataEasyExtendsBundle(),
new Sonata\DoctrineORMAdminBundle\SonataDoctrineORMAdminBundle(),
new Sonata\AdminBundle\SonataAdminBundle(),
new Application\Sonata\UserBundle\ApplicationSonataUserBundle(),
...

这是我在composer.json文件中拥有的:

"require": {
    ...
    "friendsofsymfony/user-bundle": "1.3.x-dev",
    "sonata-project/admin-bundle": "~2.3",
    "sonata-project/user-bundle": "^2.2",
    "sonata-project/doctrine-orm-admin-bundle": "~2.3",
    "sonata-project/easy-extends-bundle": "^2.1",
    ...
    "leaseweb/memcache-bundle": "*"
}

我在app/Resources/FOSUserBundle/views/Security/login.html.twig打印错误,如下所示:

{{ error|trans({}, 'FOSUserBundle') }}

每次尝试登录时,都会收到如下消息:

执行'SELECT t0.username AS username1,t0.username_canonical AS username_canonical2,t0.email AS email3,t0.email_canonical AS email_canonical4,t0.enabled AS启用5,t0.salt AS salt6,t0.password AS password7,t0时发生异常.last_login AS last_login8,t0.locked AS锁定9,t0.expired AS expired10,t0.expires_at AS expires_at11,t0.confirmation_token AS Confirm_token12,t0.password_requested_at AS password_requested_at13,t0.roles AS角色14,t0expires_credentialscreative。 AS凭据_expire_at16,t0.created_at AS created_at17,t0.updated_at AS Updated_at18,t0.date_of_birth AS date_of_birth19,t0.firstname AS firstname20,t0。 lastname AS lastname21,t0.website AS网站22,t0.biography AS传记23,t0.gender AS性别24,t0.locale AS locale25,t0.timezone AS timezone26,t0.phone AS phone27,t0.facebook_uid AS facebook_uid28,t0.facebook_name AS facebook_name29,t0.facebook_data AS facebook_data30,t0.twitter_uid AS twitter_uid31,t0.twitter_name AS twitter_name32,t0.twitter_data AS twitter_data33,t0.gplus_uid AS gplus_uid34,t0.gplus_name AS gplus_name35,t0.gplus_data AS gplus_data t0.two_step_code AS two_step_code38 FROM BaseUser t0在哪里t0.username_canonical =? 带有参数[“ admin”]的LIMIT 1':SQLSTATE [42S02]:找不到基表或视图:1146表'pdone.BaseUser'不存在

这是为什么? 这是FOSUserBundle问题还是SonataUserBundle问题? 可以给我一些建议吗?

编辑

我通过运行以下命令执行了另一项测试:

# php app/console doctrine:schema:update --dump-sql
Nothing to update - your database is already in sync with the current entity metadata.

# php app/console doctrine:schema:drop --force
Dropping database schema...
Database schema dropped successfully!

# php app/console doctrine:schema:create
ATTENTION: This operation should not be executed in a production environment.

Creating database schema...
Database schema created successfully!

再一次没有成功,同样的问题! 在所有测试中,我先清除缓存

编辑2

我运行了doctrine:mapping:info ,我得到了这个输出,为什么?

Found 18 mapped entities:
[OK]   FOS\UserBundle\Entity\User
[OK]   FOS\UserBundle\Entity\Group
[OK]   Sonata\UserBundle\Entity\BaseGroup
[OK]   Sonata\UserBundle\Entity\BaseUser
[OK]   Application\Sonata\UserBundle\Entity\User
[OK]   Application\Sonata\UserBundle\Entity\Group
[OK]   PDI\PDOneBundle\Entity\Representative
[OK]   PDI\PDOneBundle\Entity\Media
[OK]   PDI\PDOneBundle\Entity\Brand
[OK]   PDI\PDOneBundle\Entity\TerritoryBrand
[OK]   PDI\PDOneBundle\Entity\Email
[OK]   PDI\PDOneBundle\Entity\Company
[OK]   PDI\PDOneBundle\Entity\Action
[OK]   PDI\PDOneBundle\Entity\Message
[OK]   PDI\PDOneBundle\Entity\Territory
[OK]   PDI\PDOneBundle\Entity\TargetBrand
[OK]   PDI\PDOneBundle\Entity\Event
[OK]   PDI\PDOneBundle\Entity\Target

该错误非常明显,表BaseUser不存在。

找不到基表或视图:1146表'pdone.BaseUser'不存在

此外,请检查FOSUserBundle User entity类。 @ORM\\Entity某些注释( @ORM\\Entity@ORM\\Table(name="...") )。

例如

use FOS\UserBundle\Model\User as BaseUser;
use Doctrine\ORM\Mapping as ORM;

    /**
     * @ORM\Entity
     * @ORM\Table(name="fos_user")
     */
    class User extends BaseUser
    {

确保使用以下命令生成数据库表

app/console doctrine:schema:update --force

编辑:

Sonata参考资料中所述,您是否尝试过将此代码添加到config.yml

# Enable Doctrine to map the provided entities
doctrine:
    orm:
        entity_managers:
            default:
                mappings:
                    FOSUserBundle: ~
                    ApplicationSonataUserBundle: ~
                    SonataUserBundle: ~

如果命令php app/console doctrine:schema:update --dump-sql没有显示任何内容,则表示您的实体未映射。

我的第一个猜测是您需要在config.yml中添加auto_mapping而不是Sonata配置文档,这样您的实体将被自动映射。

doctrine:
    orm:
        auto_generate_proxy_classes: "%kernel.debug%"
        entity_managers:
            default:
                naming_strategy: doctrine.orm.naming_strategy.underscore
                auto_mapping: true

还要在您的app/AppKernel.php中检查是否具有扩展了FOSUserBundle的SonataUserBundle:

new Sonata\UserBundle\SonataUserBundle('FOSUserBundle')

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM