{"id":2510,"date":"2015-01-28T10:00:30","date_gmt":"2015-01-28T01:00:30","guid":{"rendered":"http:\/\/www.skyarch.net\/blog\/?p=2510"},"modified":"2015-01-28T17:27:28","modified_gmt":"2015-01-28T08:27:28","slug":"symfony2-doctrine2%e3%81%ae%e5%b0%8f%e3%83%8d%e3%82%bfonetoone%e3%83%aa%e3%83%ac%e3%83%bc%e3%82%b7%e3%83%a7%e3%83%b3","status":"publish","type":"post","link":"https:\/\/www.skyarch.net\/blog\/symfony2-doctrine2%e3%81%ae%e5%b0%8f%e3%83%8d%e3%82%bfonetoone%e3%83%aa%e3%83%ac%e3%83%bc%e3%82%b7%e3%83%a7%e3%83%b3\/","title":{"rendered":"Symfony2 Doctrine2\u306e\u5c0f\u30cd\u30bf(OneToOne\u30ea\u30ec\u30fc\u30b7\u30e7\u30f3)"},"content":{"rendered":"<p>\u304a\u4e45\u3057\u3076\u308a\u3067\u3059\u3001\u4eca\u65e5\u306f\u7720\u3044\u306e\u3067\u5927\u91cf\u306b\u30d6\u30ed\u30b0\u3092\u6295\u7a3f\u3057\u3088\u3046\u304b\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>\u672c\u65e5\u306f\u3001Table\u9593\u306eJoin\u3092\u81ea\u52d5\u5316\u3057\u3066\u304f\u308c\u308b\u3001\u3068\u3044\u3046\u304b\u304d\u3061\u3093\u3068\u8a2d\u5b9a\u3057\u306a\u3044\u3068\u307e\u3063\u305f\u304fDAO\u306e\u610f\u5473\u3092\u306a\u3055\u306a\u3044\u30ea\u30ec\u30fc\u30b7\u30e7\u30f3\u306e\u8a2d\u5b9a\u306b\u95a2\u3057\u3066\u3067\u3059\u3002<br \/>\n\u8a73\u3057\u3044\u4e2d\u8eab\u306f\u3053\u3061\u3089\u306e\u82f1\u8a9e\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u3092\u53c2\u7167\u3057\u307e\u3057\u3087\u3046\u3002<br \/>\n<a href=\"http:\/\/doctrine-orm.readthedocs.org\/en\/latest\/reference\/association-mapping.html\" title=\"http:\/\/doctrine-orm.readthedocs.org\/en\/latest\/reference\/association-mapping.html\" target=\"_blank\">http:\/\/doctrine-orm.readthedocs.org\/en\/latest\/reference\/association-mapping.html<\/a><\/p>\n<p>\u5177\u4f53\u4f8b\u3068\u3057\u3066\u4ee5\u4e0b\u306e\uff12\u3064\u306e\u30a8\u30f3\u30c6\u30a3\u30c6\u30a3\u3092\u8003\u3048\u3066\u307f\u307e\u3057\u3087\u3046<\/p>\n<p>TblTicket.php<\/p>\n<pre class=\"brush: php; title: ; notranslate\" title=\"\">\r\n&lt;?php\r\nnamespace Hoge\\FugaBundle\\Entity;\r\nuse Doctrine\\ORM\\Mapping as ORM;\r\nuse Doctrine\\Common\\Collections\\ArrayCollection;\r\n\r\n\/**\r\n *\r\n * @ORM\\Table(name=&quot;tbl_ticket&quot;)\r\n * @ORM\\Entity(repositoryClass=&quot;Hoge\\FugaBundle\\Repository\\TicketRepository&quot;)\r\n *\/\r\nclass TblTicket\r\n{\r\n    \/**\r\n     * @var bigint $id\r\n     *\r\n     * @ORM\\Column(name=&quot;id&quot;, type=&quot;bigint&quot;, nullable=false)\r\n     * @ORM\\Id\r\n     * @ORM\\GeneratedValue(strategy=&quot;IDENTITY&quot;)\r\n     *\/\r\n    protected $id;\r\n    \r\n    \/**\r\n     * @ORM\\ManyToOne(targetEntity=&quot;TblTicket&quot;, inversedBy=&quot;childs&quot;)\r\n     * @ORM\\JoinColumn(name=&quot;parent_id&quot;, referencedColumnName=&quot;id&quot;, nullable=true)\r\n     *\/\r\n    private $parent;\r\n\r\n    \/**\r\n     * @ORM\\OneToMany(targetEntity=&quot;TblTicket&quot;, mappedBy=&quot;parent&quot;)\r\n     *\/\r\n    private $childs;\r\n\r\n     \/**\r\n     * @ORM\\OneToOne(targetEntity=&quot;TblTicketData&quot;, mappedBy=&quot;ticket&quot;, cascade={&quot;persist&quot;})\r\n     *\/\r\n    private $data;\r\n\r\n\r\n    public function __construct(){\r\n        $this-&gt;childs = new ArrayCollection();\r\n    }\r\n    \r\n    \/**\r\n     * Get id\r\n     *\r\n     * @return bigint\r\n     *\/\r\n    public function getId()\r\n    {\r\n        return $this-&gt;id;\r\n    }\r\n\r\n    \/**\r\n     * get parent\r\n     * @return TblTicket\r\n     *\/\r\n    public function getParent ()\r\n    {\r\n        return $this-&gt;parent;\r\n    }\r\n\r\n    \/**\r\n     * setparent\r\n     * @param TblTicket $parent\r\n     * @return TblTicket\r\n     *\/\r\n    public function setParent ($parent)\r\n    {\r\n        $this-&gt;parent = $parent;\r\n        return $this;\r\n    }\r\n\r\n    \/**\r\n     * get data\r\n     * @return TblTicketData\r\n     *\/\r\n    public function getData ()\r\n    {\r\n        return $this-&gt;data;\r\n    }\r\n\r\n    \/**\r\n     * set data\r\n     * @param TblTicketData $parentData\r\n     * @return TblTicketData\r\n     *\/\r\n    public function setParentData ($parentData)\r\n    {\r\n        $this-&gt;parentData = $parentData;\r\n        return $this;\r\n    }\r\n\r\n\r\n\r\n\r\n    \/**\r\n     * Add childs\r\n     *\r\n     * @param TblTicket $childs\r\n     *\/\r\n    public function addChild(TblTicket $childs)\r\n    {\r\n        $this-&gt;childs&#x5B;] = $childs;\r\n    }\r\n\r\n    \/**\r\n     * Get childs\r\n     *\r\n     * @return Doctrine\\Common\\Collections\\Collection\r\n     *\/\r\n    public function getChilds()\r\n    {\r\n        return $this-&gt;childs;\r\n    }\r\n\r\n \r\n}\r\n<\/pre>\n<p>TblTicketData.php<\/p>\n<pre class=\"brush: php; title: ; notranslate\" title=\"\">\r\n&lt;?php\r\nnamespace Hoge\\FugaBundle\\Entity;\r\nuse Doctrine\\ORM\\Mapping as ORM;\r\nuse Doctrine\\Common\\Collections\\ArrayCollection;\r\n\r\n\/**\r\n * TblTicketData\r\n *\r\n * @ORM\\Table(name=&quot;tbl_ticket_data&quot;)\r\n * @ORM\\Entity\r\n *\/\r\nclass TblTicketData\r\n{\r\n    \/**\r\n     * @var bigint $id\r\n     *\r\n     * @ORM\\Column(name=&quot;id&quot;, type=&quot;bigint&quot;, nullable=false)\r\n     * @ORM\\Id\r\n     * @ORM\\GeneratedValue(strategy=&quot;IDENTITY&quot;)\r\n     *\/\r\n    private $id;\r\n\r\n    \/**\r\n     * @ORM\\OneToOne(targetEntity=&quot;TblTicket&quot;, inversedBy=&quot;data&quot;)\r\n     * @ORM\\JoinColumn(name=&quot;parent_id&quot;, referencedColumnName=&quot;id&quot;, nullable=false)\r\n     *\/\r\n    private $ticket;\r\n\r\n    \/**\r\n     * @var string $content\r\n     *\r\n     * @ORM\\Column(name=&quot;content&quot;, type=&quot;string&quot;, length=256, nullable=true)\r\n     *\/\r\n    private $content;\r\n\r\n\r\n    \/**\r\n     * Get id\r\n     *\r\n     * @return bigint\r\n     *\/\r\n    public function getId()\r\n    {\r\n        return $this-&gt;id;\r\n    }\r\n\r\n    \/**\r\n     * get parent\r\n     * @return TblTicket\r\n     *\/\r\n    public function getTicket ()\r\n    {\r\n        return $this-&gt;ticket;\r\n    }\r\n\r\n    \/**\r\n     * setparent\r\n     * @param TblTicket $parent\r\n     * @return TblTicket\r\n     *\/\r\n    public function setTicket ($ticket)\r\n    {\r\n        $this-&gt;ticket = $ticket;\r\n        return $this;\r\n    }\r\n\r\n    \/**\r\n     * get content\r\n     * @return string\r\n     *\/\r\n    public function getContent ()\r\n    {\r\n        return $this-&gt;content;\r\n    }\r\n\r\n    \/**\r\n     * set content\r\n     * @param string $content\r\n     * @return TblTicket\r\n     *\/\r\n    public function setContent ($content)\r\n    {\r\n        $this-&gt;content = $content;\r\n        return $this;\r\n    }\r\n\r\n\r\n}\r\n<\/pre>\n<p>\u3055\u3066\u3001\u307e\u305a\u306f\u4e2d\u8eab\u306e\u8aac\u660e\u306b\u79fb\u308b\u524d\u306b\u3001\u3053\u306e\u30a8\u30f3\u30c6\u30a3\u30c6\u30a3\u304b\u3089\u751f\u6210\u3055\u308c\u308b\u30c6\u30fc\u30d6\u30eb\u5b9a\u7fa9\u3092\u898b\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">\r\nCREATE TABLE tbl_ticket (\r\n  id bigint(20) NOT NULL AUTO_INCREMENT,\r\n  parent_id bigint(20) DEFAULT NULL,\r\n  PRIMARY KEY (id),\r\n  KEY IDX_1A06C41C727ACA70 (parent_id),\r\n) ENGINE=InnoDB  DEFAULT CHARSET=utf8;\r\n\r\nCREATE TABLE tbl_ticket_data (\r\n  id bigint(20) unsigned NOT NULL AUTO_INCREMENT,\r\n  ticket_id bigint(20) unsigned NOT NULL,\r\n  content varchar(255) DEFAULT NULL,\r\n  UNIQUE KEY id (id),\r\n  UNIQUE KEY ticket_id \r\n(ticket_id)\r\n) ENGINE=InnoDB  DEFAULT CHARSET=utf8;\r\n<\/pre>\n<p>\u3053\u3053\u304b\u3089\u3001\u5224\u65ad\u3067\u304d\u308b\u30dd\u30a4\u30f3\u30c8\u3092\u5217\u6319\u3057\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n<ul>\n<li>\ntbl_ticket\u306f\u6728\u69cb\u9020\u3068\u306a\u3063\u3066\u304a\u308a\u3001\u89aa\u30c1\u30b1\u30c3\u30c8\u3092\u81ea\u8eab\u306e\u30c6\u30fc\u30d6\u30eb\u306b\u6301\u3063\u3066\u3044\u308b\n<\/li>\n<li>\ntbl_ticket\u306f\u4e00\u756a\u89aa\u306e\u30c1\u30b1\u30c3\u30c8\u3092\u5224\u65ad\u3059\u308b\u305f\u3081\u306b\u3001parent_id\u306bNull\u3092\u8a31\u53ef\u3057\u3066\u3044\u308b\n<\/li>\n<li>\ntbl_ticket\u306f\u305d\u306e\u30c1\u30b1\u30c3\u30c8\u306b\u4ed8\u968f\u3059\u308b\u30c7\u30fc\u30bfticket_data\u3092\uff11\u3064\u6301\u3063\u3066\u3044\u308b\n<\/li>\n<\/ul>\n<p>\u305d\u308c\u3067\u306f\u3001\u30a8\u30f3\u30c6\u30a3\u30c6\u30a3\u306e\u4e2d\u8eab\u3092\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3001<\/p>\n<h1>@OneToOne<\/h1>\n<p>TblTicket.php \u3068 TblTicketData.php\u306b\u306f\u305d\u308c\u305e\u308c@OneToOne\u30a2\u30ce\u30c6\u30fc\u30b7\u30e7\u30f3\u304c\u3042\u308a\u307e\u3059\u304c\u4e2d\u8eab\u304c\u5c11\u3005\u9055\u3046\u3088\u3046\u3067\u3059\u3002<\/p>\n<p>TblTicket.php<\/p>\n<pre class=\"brush: php; title: ; notranslate\" title=\"\">\r\n@ORM\\OneToOne(targetEntity=&quot;TblTicketData&quot;, mappedBy=&quot;ticket&quot;, cascade={&quot;persist&quot;})\r\n<\/pre>\n<p>TblTicketData.php<\/p>\n<pre class=\"brush: php; title: ; notranslate\" title=\"\">\r\n@ORM\\OneToOne(targetEntity=&quot;TblTicket&quot;, inversedBy=&quot;data&quot;)\r\n@ORM\\JoinColumn(name=&quot;parent_id&quot;, referencedColumnName=&quot;id&quot;, nullable=false)\r\n<\/pre>\n<p>\u30dd\u30a4\u30f3\u30c8\u306f<\/p>\n<ul>\n<li>\u6240\u5c5e\u3059\u308b\u5074\u306e\u30c7\u30fc\u30bf(TblTicketData)\u306b\u306finversedBy\u3068JoinColumn\u3092\u4ed8\u4e0e\u3059\u308b<\/li>\n<li>\u6240\u5c5e\u3055\u308c\u308b\u5074\u306e\u30c7\u30fc\u30bf(TblTicket)\u306b\u306fmappedBy\u3092\u4ed8\u4e0e\u3059\u308b<\/li>\n<li>JoinColumn\u306b\u3088\u3063\u3066TblTicketData\u306eparent_id\u3068TblTicket\u306eid\u9593\u306e\u30ea\u30ec\u30fc\u30b7\u30e7\u30f3\u304c\u4f5c\u3089\u308c\u308b<\/li>\n<li>nullable=false\u306b\u3088\u3063\u3066\u3001\u3059\u3079\u3066\u306e\u30c7\u30fc\u30bf\u306f\u5fc5\u305aTblTicket\u3078\u306e\u6240\u5c5e\u304c\u4fdd\u969c\u3055\u308c\u308b<\/li>\n<\/ul>\n<p>\u3067\u3059\u3002<\/p>\n<p>\u3067\u306f\u3001\u7d9a\u3044\u3066\u3001\u3053\u306e\u30c7\u30fc\u30bf\u306eInsert\u306b\u95a2\u3057\u3066\u8003\u3048\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<h2>\u30d1\u30bf\u30fc\u30f31<\/h2>\n<pre class=\"brush: php; title: ; notranslate\" title=\"\">\r\npublic function createAction()\r\n{\r\n    $ticket = new TblTicket();\r\n    $data   = new TblTicketData();\r\n    $data-&gt;setContent(&quot;aaaa&quot;);\r\n    $data-&gt;setTicket($ticket);\r\n    $em = $this-&gt;getDoctrine()-&gt;getEntityManager();\r\n    $em-&gt;persist($ticket);\r\n    $em-&gt;persist($data);\r\n    $em-&gt;flush();\r\n\r\n    return new Response('Created product');\r\n}\r\n<\/pre>\n<p>$data\u306b\u306f\u3001ticket_id\u304c\u5fc5\u8981\u306a\u306e\u3067\u3001TblTicket\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u3092\u30bb\u30c3\u30c8\u3057\u306a\u3044\u3068Error\u3068\u306a\u3063\u3066\u3057\u307e\u3044\u307e\u3059\u3002<\/p>\n<p>\u305f\u3060\u3057\u4eca\u56de\u306f\u3001cascade={\"persist\"}\u3092TblTicket\u306b\u4ed8\u4e0e\u3057\u3066\u3044\u308b\u305f\u3081\u3001\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u306b\u3088\u3063\u3066\u3082Insert\u53ef\u80fd\u3067\u3059\u3002<\/p>\n<h2>\u30d1\u30bf\u30fc\u30f32<\/h2>\n<pre class=\"brush: php; title: ; notranslate\" title=\"\">\r\npublic function createAction()\r\n{\r\n    $ticket = new TblTicket();\r\n    $data   = new TblTicketData();\r\n    $data-&gt;setContent(&quot;aaaa&quot;);\r\n    $data-&gt;setTicket($ticket);\r\n    $ticket-&gt;setData($data);\r\n    $em = $this-&gt;getDoctrine()-&gt;getEntityManager();\r\n    $em-&gt;persist($ticket);\r\n    $em-&gt;flush();\r\n\r\n    return new Response('Created product');\r\n}\r\n<\/pre>\n<p>\u3053\u308c\u306f\u3001persist\u306e\u969b\u306b\u30a8\u30f3\u30c6\u30a3\u30c6\u30a3\u30de\u30cd\u30fc\u30b8\u30e3\u30fc\u304c\u7ba1\u7406\u3057\u3066\u3044\u306a\u3044\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306b\u95a2\u3057\u3066\u3082\u307e\u3068\u3081\u3066persist\u3059\u308b\u3068\u3044\u3046\u8a2d\u5b9a\u306b\u3088\u308b\u3082\u306e\u3067\u3059\u3002<\/p>\n<h2>\u6ce8\u610f<\/h2>\n<pre class=\"brush: php; title: ; notranslate\" title=\"\">\r\npublic function errorAction()\r\n{\r\n    $em     = $this-&gt;getDoctrine()-&gt;getEntityManager();\r\n    $repo   = $em-&gt;getRepository(&quot;HogeFugaBundle:TblTicket&quot;);\r\n    \r\n    $ticket = $repo-&gt;find(1);\r\n    \/\/ \u30a8\u30e9\u30fc\u51fa\u308b\u304b\u3082\r\n    echo $ticket-&gt;getData()-&gt;getContent();\r\n\r\n    return new Response('get content');\r\n}\r\n<\/pre>\n<p>mappedBy\u306eOneToOne\u3067\u306f\u3001\u5bfe\u8c61\u30a8\u30f3\u30c6\u30a3\u30c6\u30a3\u306e\u30c7\u30fc\u30bf\u306e\u5b58\u5728\u3092\u4fdd\u8a3c\u3067\u304d\u306a\u3044(\u9006\u306e\u5834\u5408\u306f\u4fdd\u8a3c\u3055\u308c\u308b)\u306e\u3067\u3001Data\u304cNull\u306e\u5834\u5408\u304c\u3042\u308a\u3048\u307e\u3059<\/p>\n<p>OneToMany\u3082\u3084\u308a\u305f\u304b\u3063\u305f\u306e\u3067\u3059\u304c\u3001\u91cf\u304c\u591a\u304f\u306a\u3063\u3066\u3057\u307e\u3063\u305f\u306e\u3067\u305d\u308c\u306f\u6b21\u56de\u306b\u56de\u3057\u307e\u3059\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u304a\u4e45\u3057\u3076\u308a\u3067\u3059\u3001\u4eca\u65e5\u306f\u7720\u3044\u306e\u3067\u5927\u91cf\u306b\u30d6\u30ed\u30b0\u3092\u6295\u7a3f\u3057\u3088\u3046\u304b\u3068\u601d\u3044\u307e\u3059\u3002 \u672c\u65e5\u306f\u3001Table\u9593\u306eJoin\u3092\u81ea\u52d5\u5316\u3057\u3066\u304f\u308c\u308b\u3001\u3068\u3044\u3046\u304b\u304d\u3061\u3093\u3068\u8a2d\u5b9a\u3057\u306a\u3044\u3068\u307e\u3063\u305f\u304fDAO\u306e\u610f\u5473\u3092\u306a\u3055\u306a\u3044\u30ea\u30ec\u30fc\u30b7\u30e7\u30f3\u306e\u8a2d\u5b9a\u306b\u95a2\u3057\u3066\u3067\u3059\u3002 \u8a73\u3057\u3044\u4e2d&#8230;<\/p>\n","protected":false},"author":34,"featured_media":1751,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_locale":"","_original_post":"","footnotes":""},"categories":[23,9],"tags":[],"class_list":{"0":"post-2510","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-23","8":"category-dev","9":"ja"},"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/www.skyarch.net\/blog\/wp-json\/wp\/v2\/posts\/2510","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.skyarch.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.skyarch.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.skyarch.net\/blog\/wp-json\/wp\/v2\/users\/34"}],"replies":[{"embeddable":true,"href":"https:\/\/www.skyarch.net\/blog\/wp-json\/wp\/v2\/comments?post=2510"}],"version-history":[{"count":6,"href":"https:\/\/www.skyarch.net\/blog\/wp-json\/wp\/v2\/posts\/2510\/revisions"}],"predecessor-version":[{"id":2521,"href":"https:\/\/www.skyarch.net\/blog\/wp-json\/wp\/v2\/posts\/2510\/revisions\/2521"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.skyarch.net\/blog\/wp-json\/wp\/v2\/media\/1751"}],"wp:attachment":[{"href":"https:\/\/www.skyarch.net\/blog\/wp-json\/wp\/v2\/media?parent=2510"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.skyarch.net\/blog\/wp-json\/wp\/v2\/categories?post=2510"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.skyarch.net\/blog\/wp-json\/wp\/v2\/tags?post=2510"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}