「Php/Symfony/Symfony2/doctrine/基本」の版間の差分
提供: 初心者エンジニアの簡易メモ
(ページの作成:「==db設定== app/config/parameters.ini parameters database_driver = pdo_mysql database_host = localhost database_name = project1 database_user...」) |
(→generateでテーブルクラスを作った場合) |
||
行44: | 行44: | ||
*/ | */ | ||
private $id; | private $id; | ||
− | + | ||
/** | /** | ||
* @var string | * @var string | ||
行51: | 行51: | ||
*/ | */ | ||
private $name; | private $name; | ||
− | + | ||
/** | /** | ||
* @var string | * @var string | ||
行68: | 行68: | ||
return $this->id; | return $this->id; | ||
} | } | ||
− | + | ||
/** | /** | ||
* Set name | * Set name | ||
行90: | 行90: | ||
return $this->name; | return $this->name; | ||
} | } | ||
− | + | ||
/** | /** | ||
* Set description | * Set description | ||
行103: | 行103: | ||
return $this; | return $this; | ||
} | } | ||
− | + | ||
/** | /** | ||
* Get description | * Get description |
2016年12月22日 (木) 14:40時点における版
目次
db設定
app/config/parameters.ini parameters database_driver = pdo_mysql database_host = localhost database_name = project1 database_user = user1 database_password = *****
dbのschemaを作る
php app/console doctrine:database:create
or
create database project1;
テーブルクラス作成
-Acme/HelloBundle/Entity/User.php
namespace Acme\HelloBundle\Entity; class User { protected $name; protected $description; }
generateでテーブルクラスを作った場合
dbとのマッピング処理などが追加された記述をして作成される
$ php app/console doctrine:generate:entity --entity="AcmeHelloBundle:User" --fields="name:string(255) description:text"
-Acme/HelloBundle/Entity/User.php
namespace Acme\HelloBundle\Entity; use Doctrine\ORM\Mapping as ORM; /** * User * * @ORM\Table() * @ORM\Entity */ class User { /** * @var integer * * @ORM\Column(name="id", type="integer") * @ORM\Id * @ORM\GeneratedValue(strategy="AUTO") */ private $id; /** * @var string * * @ORM\Column(name="name", type="string", length=255) */ private $name; /** * @var string * * @ORM\Column(name="description", type="text") */ private $description; /** * Get id * * @return integer- */ public function getId() { return $this->id; } /** * Set name * * @param string $name * @return User2 */ public function setName($name) { $this->name = $name;
return $this; } /** * Get name * * @return string- */ public function getName() { return $this->name; } /** * Set description * * @param string $description * @return User2 */ public function setDescription($description) { $this->description = $description;
return $this; } /** * Get description * * @return string- */ public function getDescription() { return $this->description; } }
generateしたテーブルクラスからdb側のtableを作る
$ php app/console doctrine:schema:update --force CREATE TABLE `User2` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) COLLATE utf8_unicode_ci NOT NULL, `description` longtext COLLATE utf8_unicode_ci NOT NULL, PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci
insert処理
$user = new \Acme\HelloBundle\Entity\User(); $user->setName('taro'); $user->setDescription('太郎です'); $em = $this->getDoctrine()->getEntityManager(); $em->persist($user); $em->flush(); // ここでinsert処理がされる
select * from User; +----+-----------+-------------------+ | id | name | description | +----+-----------+-------------------+ | 1 | taro | 太郎です | +----+-----------+-------------------+
select処理
$repository = $this->getDoctrine() ->getRepository('AcmeHelloBundle:User'); $user = $repository->find(1); // userクラスにデータを入れて取得 if ($user) { echo $user->getId(); // taro echo $user->getName(); // 太郎です }