使用框架操作数据库的几个要求

1.安全,比如防止sql注入等,pdo里面prepare,execute 就可以

2.性能,数据库操作是最基本的操作,频繁使用,需要考虑到执行效率

3.ORM(object relation mapper)可以将数据映射到一个类当中,pdo也是支持的,

4.支持多种数据库(不常用)

5.能使用第三方插件,比如现在需要对五个表进行排序,可以将排序功能封装起来,每个表都可以使用去实现各自的排序功能,这时就可以从网上下载第三方代码,只需要继承该代码

即可实现排序功能。即自动实现相同功能的集合

。。。。很明显Doctirne这些条件都满足了

下面我们对Doctirne2先进行一个预览

/**
* @Route("/")
*/
class DefaultController extends Controller
{
/**
* @Route("/index",name="page_index")
* @Template()
*/
public function indexAction()
{
$user = $em->getRepository('User')->findOneBy(array("id"=>1));
$user->setName("test"); foreach($user->getAdressBooks() as $adressBook){
echo $adressBook->getName();
}
$em->presist($user);
$em->flush(); }
}

可以看到,首先$em是传进来的一个对象,getRepositor('User')获取user信息,之后以id为1进行分类,返回一个用户数组给$user

,setName()  对用户的名字进行设置,$em->presist()将我们更改的信息交给$em托管,之后$em会自动进行处理,生成一个update语句,更改表中id为1的名字,flush() 刷新即完成更改。

中间的getAdressBooks,是假定user表和adressbooks表示一对多的关系,获取该用户对应的所有adressbooks,遍历并输出其name。、

可以看到没有像之前一样,编写复杂的sql语句进行查询更新,就完成了这些操作。在symfony网页下方也可以查看生成的sql语句

下面先了解几个基本的doctrine2概念,之后进行配置

1.Entity

类似于一个对象, 里面有各种字段以及属性,并且像mysql一样,其间有各种关系。比如刚才所用$em就是

2.Repository

一个操作集合,比如前面的getRepository()->findOneBy();将查找用户操作放在getRepository里面,选取相应的操作即可,

将数据库相关的业务逻辑操作封装起来,直接调用就行,

3.Proxy

像之前的$user,他并不是一开始就将所有SQL语句都生成出来,将所有信息都存放在$user之中,而是当你需要哪个信息的时候,

他才生成sql语句,执行查询操作,得到相应数据,相当于句动态查询的。

而当还没有查询之前的$user,就处于proxy状态,虚拟状态,用到的时候才会将其 实例化进行使用.

4.DQL语句

构建查询语句,比sql更简单一些,

$query = $em->createQuery(
select u from database:User p where u.name=:name'
)setParameter('name','scourgen');

上面的例子就是一个dql查询语句

下面的例子和上面的等价,不过是动态构建了一个DQL语句,更为面向对象化,可以将每一个语句都当做一个方法去替换他

$query = $em->getRepository('User')->createQueyBuilder('U')
->where('u.name=:name')
->setParmameter('name','scourgen')
->getQuery();

5.事件监听机制

比如现在有一个事件会做很多事情,如果要每次都手动都添加时间戳进行记录,会很麻烦。所以DOCTRINE2为我们提供了这种自动监听机制,不需要去手动监听

Doctrine2-基础概念的更多相关文章

  1. 【Machine Learning】机器学习及其基础概念简介

    机器学习及其基础概念简介 作者:白宁超 2016年12月23日21:24:51 摘要:随着机器学习和深度学习的热潮,各种图书层出不穷.然而多数是基础理论知识介绍,缺乏实现的深入理解.本系列文章是作者结 ...

  2. TCP/IP基础概念及通信过程举例

    TCP/IP基础概念及通信过程举例 出现 上个世纪60年代,由于中央集中式网络的容灾性较弱,以美国国防部为中心的一家组织研究出分组交换网络.后来为了验证分组交换技术的实用性,ARPANET出现了,并且 ...

  3. Jmeter基础之---jmeter基础概念

    Jmeter基础之---jmeter基础概念 JMeter 介绍: 一个非常优秀的开源的性能测试工具. 优点:你用着用着就会发现它的重多优点,当然不足点也会呈现出来. JMeter 介绍: 一个非常优 ...

  4. 快速入门系列--WCF--01基础概念

    转眼微软的WCF已走过十个年头,它是微软通信框架的集大成者,将之前微软所有的通信框架进行了整合,提供了统一的应用方式.记得从自己最开始做MFC时,就使用过Named Pipe命名管道,之后做Winfo ...

  5. 理解 angular2 基础概念和结构 ----angular2系列(二)

    前言: angular2官方将框架按以下结构划分: Module Component Template Metadata Data Binding Directive Service Dependen ...

  6. JavaBean 基础概念、使用实例及代码分析

    JavaBean 基础概念.使用实例及代码分析 JavaBean的概念 JavaBean是一种可重复使用的.且跨平台的软件组件. JavaBean可分为两种:一种是有用户界面的(有UI的):另一种是没 ...

  7. RabbitMQ基础概念详细介绍

    http://blog.csdn.net/column/details/rabbitmq.html 转至:http://www.ostest.cn/archives/497 引言 你是否遇到过两个(多 ...

  8. linux设备驱动归纳总结(二):模块的相关基础概念【转】

    本文转载自:http://blog.chinaunix.net/uid-25014876-id-59415.html linux设备驱动归纳总结(二):模块的相关基础概念 系统平台:Ubuntu 10 ...

  9. linux设备驱动归纳总结(一)内核的相关基础概念【转】

    本文转载自:http://blog.chinaunix.net/uid-25014876-id-59413.html linux设备驱动归纳总结(一):内核的相关基础概念 xxxxxxxxxxxxxx ...

  10. 什么是JavaScript闭包终极全解之一——基础概念

    本文转自:http://www.cnblogs.com/richaaaard/p/4755021.html 什么是JavaScript闭包终极全解之一——基础概念 “闭包是JavaScript的一大谜 ...

随机推荐

  1. 4.1 socket

    socket  背景概念 脑图结构 OSI 模型 socket 概念特性 脑图结构 理解示意图  额外补充 Socket是应用层与 TCP/IP协议族通信的中间软件抽象层,它是一组接口. 在设计模式中 ...

  2. [CTSC2018]暴力写挂

    题目描述 www.lydsy.com/JudgeOnline/upload/201805/day1(1).pdf 题解 首先来看这个我们要最大化的东西. deep[u]+deep[v]-deep[lc ...

  3. python xpath学习

    一.选取节点: 二.谓词: 注意:在scrapy中用xpath进行搜索时,如果使用相对路径,要加上.,如,不然搜索的是整个文档.

  4. MQ在高并发环境下,如果队列满了,如何防止消息丢失?

    1.为什么MQ能解决高并发环境下的消息堆积问题? MQ消息如果堆积,消费者不会立马消费所有的消息,不具有实时性,所以可以解决高并发的问题. 性能比较好的消息中间件:Kafka.RabbitMQ,Roc ...

  5. IIC协议理解(转)

    目录 IIC协议理解(转) 个人小结记录 (记一下这个就够了) 以下为转载记录 概述 概述 输出级 主设备与从设备 速率 时序 空闲状态 起始位与停止位 数据的有效性 数据的传送 工作过程 主设备向从 ...

  6. GO语言系列(四)- 内置函数、闭包与高级数据类型

    一.内置函数.递归函数.闭包 内置函数 1. close:主要用来关闭channel 2. len:用来求长度,比如string.array.slice.map.channel 3. new:用来分配 ...

  7. DirectX11 With Windows SDK--09 纹理映射与采样器状态

    前言 在之前的DirectX SDK中,纹理的读取使用的是D3DX11CreateShaderResourceViewFromFile函数,现在在Windows SDK中已经没有这些函数,我们需要找到 ...

  8. 工作任务: 批量处理wav音频文件--shell脚本

    #!/bin/bash # 处理音频 deal_with_wav() { ) do ) do # gd1_music ./tool/fixbeam2 -c res/fixbeam2.bin -b -i ...

  9. Python列表中查找某个元素的索引(多个)

    enumerate() 函数用于将一个可遍历的数据对象(如列表.元组或字符串)组合为一个索引序列,同时列出数据和数据下标,一般用在 for 循环当中. 以下是 enumerate() 方法的语法: e ...

  10. SpringMVC中的数据绑定(也就是参数的接收)

    spirngMVC中的数据绑定类型,分为默认数据类型,简单数据类型,pojo类型,包装的pojo类型,绑定数组类型,绑定集合类型,还有自定定义数据绑定. 例如默认数据类型的绑定@RequestMapp ...