ORM を使用して PHP データベース接続を簡素化し、リレーショナル データベース内のテーブルとデータをアプリケーション内のオブジェクトにマップします。これにより、データベースとの対話が大幅に簡素化されます。 ORM の利点には、簡略化された CRUD 操作、自動マッピング、オブジェクト関係、および保守性の向上が含まれます。実践例: Doctrine フレームワークを使用して PHP でエンティティを作成および永続化し、エンティティを永続化コンテキストに追加して変更をコミットすることでデータベースと対話します。
ORM を使用して PHP データベース接続を簡素化する
オブジェクト リレーショナル マッピング (ORM) は、リレーショナル データベース内のテーブルとデータをアプリケーション内のオブジェクトにマップするパターンです。 ORM を使用すると、データベースとの対話が大幅に簡素化され、開発効率とコードの保守性が向上します。
ORMとは何ですか?
ORM は、オブジェクト データベースとリレーショナル データベースの間の抽象化レイヤーとして機能します。オブジェクトのプロパティをデータベース テーブルの列に自動的にマップし、作成、読み取り、更新、削除 (CRUD) 操作に便利なメソッドを提供します。
利点
ORM を使用する主な利点は次のとおりです:
実践事例
PHP で人気の ORM フレームワーク Doctrine を使用して実践事例を提供します。
Doctrineのインストール
composer require doctrine/orm
設定ファイル
config/orm.yml
設定ファイルは次のとおりです: config/orm.yml
中的配置文件如下:
doctrine: dbal: url: 'mysql://root:@localhost:3306/doctrine_db' driver: pdo_mysql orm: auto_generate_proxy_classes: true metadata_cache_driver: array query_cache_driver: array
实体定义
创建用于映射到数据库表的实体:
// src/Entity/Product.php namespace App\Entity; use Doctrine\ORM\Mapping as ORM; /** * @ORM\Entity */ class Product { /** * @ORM\Id * @ORM\GeneratedValue * @ORM\Column(type="integer") */ private $id; /** * @ORM\Column(type="string", length=255) */ private $name; /** * @ORM\Column(type="float") */ private $price; // 省略其他代码... }
使用 ORM
在控制器中使用Doctrine创建一个新产品:
// src/Controller/ProductController.php namespace App\Controller; use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; use Symfony\Component\HttpFoundation\Request; use App\Entity\Product; use Doctrine\ORM\EntityManagerInterface; class ProductController extends AbstractController { public function create(Request $request, EntityManagerInterface $entityManager) { $product = new Product(); $product->setName('New Product'); $product->setPrice(10.99); $entityManager->persist($product); $entityManager->flush(); return $this->redirectToRoute('product_index'); } }
在上面的示例中,persist()
方法将新产品添加到与持久性上下文关联的管理对象列表中。flush()
rrreee
persist()
メソッドは新しいプロダクトを永続化コンテキスト依存オブジェクトに追加します管理対象オブジェクトのリスト。 flush()
メソッドは、永続コンテキストに対するすべての変更をデータベースにコミットします。 🎜以上がORM (オブジェクト リレーショナル マッピング) を使用して PHP データベース接続を簡素化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。