- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在使用 Doctrine2 开发 Symfony2/mySQL 项目。在我们的概念中,我们有一个“ super ”抽象类,它由抽象子类扩展,而抽象子类本身又由具体类扩展。
这是我的代码:
<?php
namespace AppBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
/**
* Description of SuperAbstractClass
*
* @author gbrugiere
* @ORM\Table(name="superabstractclass")
* @ORM\Entity
* @ORM\InheritanceType("JOINED")
* @ORM\DiscriminatorColumn(name="discr", type="string", length=2)
* @ORM\DiscriminatorMap({"AC" = "AbstractClass","C1" = "ConcreteClass1", "C2" = "ConcreteClass2"})
*/
abstract class SuperAbstractClass {
/**
* @var integer
*
* @ORM\Column(name="id", type="integer", nullable=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
* @var string
*
* @ORM\Column(name="label", type="text", nullable=false)
*/
protected $label;
/**
* Get id
*
* @return integer
*/
public function getId()
{
return $this->id;
}
/**
* Set libellé
*
* @param string $label
* @return SuperAbstractClass
*/
public function setLabel($label)
{
$this->label = $label;
return $this;
}
/**
* Get libellé
*
* @return string
*/
public function getLabel()
{
return $this->label;
}
}
?>
然后:
<?php
namespace AppBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
/**
* Description of SuperAbstractClass
*
* @author gbrugiere
* @ORM\Table(name="abstractclass")
* @ORM\Entity
* @ORM\InheritanceType("JOINED")
* @ORM\DiscriminatorColumn(name="discr", type="string", length=2)
* @ORM\DiscriminatorMap({"C1" = "ConcreteClass1", "C2" = "ConcreteClass2"})
*/
abstract class AbstractClass extends SuperAbstractClass {
/**
* @var string
*
* @ORM\Column(name="souslibelle", type="text", nullable=false)
*/
protected $sousLibelle;
/**
* Set sous-libellé
*
* @param string $sousLibelle
* @return AbstractClass
*/
public function setSousLibelle($sousLibelle)
{
$this->sousLibelle = $sousLibelle;
return $this;
}
/**
* Get sous-libellé
*
* @return string
*/
public function getSousLibelle()
{
return $this->sousLibelle;
}
}
?>
这是我的最后一个代码:
<?php
namespace AppBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
/**
* Description of ConcreteClass1
*
* @author gbrugiere
* @ORM\Table(name="concreteclass1")
* @ORM\Entity
*/
class ConcreteClass1 extends AbstractClass {
/**
* @var string
*
* @ORM\Column(name="details", type="text", nullable=false)
*/
private $details;
/**
* Set details
*
* @param string $details
* @return ConcreteClass1
*/
public function setDetails($details)
{
$this->details = $details;
return $this;
}
/**
* Get details
*
* @return string
*/
public function getDetails()
{
return $this->details;
}
}
?>
当我生成 SQL 代码时,我得到:
CREATE TABLE superabstractclass (id INT AUTO_INCREMENT NOT NULL, libelle LONGTEXT NOT NULL, discr VARCHAR(2) NOT NULL, PRIMARY KEY(id))
DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB;
CREATE TABLE abstractclass (id INT NOT NULL, subLabel LONGTEXT NOT NULL, PRIMARY KEY(id))
DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB;
CREATE TABLE concreteclass1 (id INT NOT NULL, details LONGTEXT NOT NULL, PRIMARY KEY(id))
DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB;
CREATE TABLE concreteclass2 (id INT NOT NULL, detailsautres LONGTEXT NOT NULL, PRIMARY KEY(id))
DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB;
ALTER TABLE abstractclass
ADD CONSTRAINT FK_438A1A85BF396750 FOREIGN KEY (id)
REFERENCES superabstractclass (id) ON DELETE CASCADE;
ALTER TABLE concreteclass1
ADD CONSTRAINT FK_474E75CFBF396750 FOREIGN KEY (id)
REFERENCES superabstractclass (id) ON DELETE CASCADE;
我对最后一行感到有点惊讶。为什么我的 concreteclass1
表引用 superabstractclass
(请参阅 *FK_474E75CFBF396750*
)而不是 abstractclass
。我担心我的数据完整性:如果删除 abstractclass
行会发生什么。我仍然会有一个 superabstractclass
和一个 concreteclass1
行(表示对象实例),但我会丢失有关对象的一些信息。
我错过了什么吗?我已经搜索了几个小时,但没有找到任何东西。感谢您的帮助。
最佳答案
我推荐以下设置:
/**
* @ORM\MappedSuperclass
*/
abstract class SuperAbstractClass {...}
和
/**
* @ORM\MappedSuperclass
*/
abstract class AbstractClass extends SuperAbstractClass {...}
和
/**
* @ORM\Table(name="concreteclass1")
* @ORM\Entity
*/
class ConcreteClass1 extends AbstractClass {...}
这将在您的架构中仅创建一个表(名为creteclass1)并具有Concrete、Abstract 和SuperAbstractClass 的所有属性。您仍然可以使用通用功能(例如 id 生成将起作用)。
如果您有一个额外的 ConcreteClass,它将创建一个新的表/实体,然后再次继承您需要的任何内容。
我们也有这样的设置 - 根据我的理解,这里不需要有联合继承。
关于php - 在 Doctrine : curious database generation 中使用抽象子类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32440815/
我是 Julia 的新手。 我主要用python编程。 在 python 中, 如果你想迭代大量的值, 通常构造一个所谓的生成器来节省内存使用。 这是一个示例代码: def generator(N):
这个问题很奇怪。我试图直接在 build.gradle 中添加一个字符串,因为我需要它来使用 Tray 库 ( https://github.com/grandcentrix/tray )。在我的第一
我正在尝试在我的新 symfony3 项目中使用生成 CRUD 功能。我创建了一个名为 AdminBundle 的 bundle ,其中包含生成器、实体测试以及生成器,所有这些都处理得很好。我检查了我
我尝试理解生成器,但我发现了一个我无法遵循的示例。 // First Generator function* Colors () { yield "blue"; yield* MoreColo
我将制作一款完全由程序生成的空间/交易/战斗游戏。但是,我知道将整个星系的所有细节存储在内存中是不可行的。因此,我一直认为我可以使用种子来生成太阳系,并且从该太阳系,您可以使用跳跃门前往其他太阳系。问
我在 Eclipse Helios 中使用 MyBatis Generator (MyBatis Generator 1.3.1.201101032122),但每次我自动生成持久类时,生成器都会删除属
@GenerateInterface class A {} @GenerateInterface class B { void setA(IA a) {} } 我的注释处理器应该生成这些接口(in
我刚刚在一个空目录中安装了 yeoman,它打印出一个错误。这就是我所做的: npm i yo -g npm i generator-webapp -g 之后我抛出一个错误: require('yeo
我正在使用 NReco PDFGenerator 从 HTML 字符串创建 PDF 文档。当表格被分页符拆分时,表格标题与表格中的下一行重叠(见下图)。 有想法该怎么解决这个吗? 最佳答案 我发现这是
我有这个命名空间: namespace :manage do # Directs /manage/products/* to Manage::ProductsController
我有一个 Open API 3 规范的 yaml 文件,它有一些 x- 前缀的属性。我正在尝试使用 openapi-generator-cli 生成一个 Angular Typescript SDK。
我有一个返回生成器的函数。目前它使用yield from: function foo() { $generator = getGenerator(); // some other st
我选择Symfony2 docs 。据说添加 /** * @ORM\Entity(repositoryClass="Acme\StoreBundle\Entity\ProductRepository
运行命令生成新的 rails 项目: $ rails generate controller home index 以上将创建四个新的 Rails 项目:generate、controller、hom
我们实际上已经将jvm内存增加到了256M,现在老年代看起来很小,但Perm Generation相当高,接近80%。通过 jstat 捕获的示例数据如下。高永久代意味着什么? Timestamp
class Invoice def Invoice.generate(order_id, charge_amount, credited_amount = 0.0) Invoice.new
我在写 this comparison为了帮助人们理解所有这些废话,目前看来,generator-angular 的好处和值(value)只是您使用 generator-angular-fullsta
我有一个包含以下代码段的 OpenAPI 规范文档(我无法控制): servers: - url: http://www.[someservice].com/api 我正在使用这个 OpenAPI
我正在使用 openapi-yaml 将 swagger 文件转换为开放的 API v3 文件。使用 Maven 生成器。 我想做的是将新文件直接放入某个目录。 但是会生成一些我不需要的其他文件,例如
我的生成器中有以下标准文件夹结构。我当前正在努力解决的任务是我目前有一个模板化的 _package.json ,我将其写入磁盘以用于主要生成。我想在编写的 package.json 中包含一个变量,它
我是一名优秀的程序员,十分优秀!