---恢复内容开始---

下面用Doctrine2设置配置一个数据库,具体分为以下步骤

1.设计主要字段和表

2.配置symfony2和数据库的连接

3.配置Entity,定义类

4.实现get/set/Reposistory

5.生成数据库

先记录一个坑

这里在配置entity时,执行命令php app/console generate:doctrine:entities ScourgenWebBundle会有错误产生

[Doctrine\Common\Annotations\AnnotationException]
[Semantical Error] The annotation "@Doctrine\ORM\Mapping\GenerateValue" in property Scourgen\WebBundle\Entity\user:
:$id does not exist, or could not be auto-loaded.

可以经过检查明明是,$id明明定义了,查阅各种资料无果,最后尝试将protect $id放在ID的annoation之前,就成功了,不太明白原理,反正是个坑吧,

网上目前也没有搜索到解决方法。但是这样子就可以了,希望遇到同样问题的朋友可以这样子解决,欢迎讨论其中原理。这样子不行,之后还是会有错误,,,,,等我再搜索搜索

.............原来是一个简单的地方拼写错误导致无法识别,佛了!!!!!!!!!!!!!!之前成功是因为跳过了id字段,

1.第一步,设计主要字段和表,如图

昨天晚上写完忘记保存了,,,,,,,这里简单来说一下表之间的关系吧

user和profile   一对一关系

user和book   多对多关系

book 和category  多对多关系

book和author  多对一关系

author和category 一对多关系

2.设计数据库和symfony的连接,

这一步很简单,就是改变symfony项目当中app/config/php文件之中的参数即可,改为本地mysql数据库参数

3.配置Entity,定义类

首先说一下我对这一步的理解,实质上来讲就是将数据库当中的表映射为php的类,这样子,我们来在操作数据库时,需要进行各种sql语句的书写,但是如果映射到类,各种操作就可变为

直接对一个对象进行操作,调用各种方法,doctrine会帮我们自动生成sql语句,操作数据库,这样就可极大的提高开发效率。并且在创建表时,我们也是只需要定义php的各种类,之后进行

php app/console doctrine:generate:entities 以及doctrine:schema:update 命令更新数据库,这样就会自动在数据库当中生成表。生成之前,可以用 dectrine:schema:validate检查annoatation

是否正确,以便后续更新数据库。

接下来先对deoctrine\ORM\Mapping  的一对一,一对多,多对多,加入表等模块进行学习,之后运用进行entity的配置

这里附上doctrine的官方文档之中关于working with Object

https://www.doctrine-project.org/projects/doctrine-orm/en/2.6/reference/working-with-objects.html#

下面用代码进行简单的说明

use Doctrine\ORM\Mapping\OneToOne;
use Doctrine\ORM\Mapping\ManyToMany;
use Doctrine\ORM\Mapping as ORM;
//剩下的模块导入类似,这里不再说说明
/**
*设置生成的repository的名字,这里绝对路径,前面要用namespace
*@ORM\Entity(repositoryClass="AuthorRepository")
*@ORM\Table(name="author") 数据库当中表的名字
*/
class Author{
/**
*@ORM\Id 说明是主键
*@ORM\Column(type="integer") 说明字段类型
*/
protected $id;
/**
*@Column(type="string") 定义普通的字段只需说明类型
*/
protected $name;
/**
*@OneToMany(targetEntity="Book",mappedBy="author")
一对多关系,指向目标entity,mappedBy参数代表映射字段, */
protected $books;
}

下面演示book_entity,即多对一关系和多对多关系的书写方法

//use 同上,省去
/**
*@ORM\Entity(repositoyClass="BookRepository")
*@ORM\Table(name="book") 同上
*/ class Book{
//这里不进行重复演示
/**
*多对一关系,和author当中的books对应,由于多对一关系
*所以需要在多的那个表当中添加外键,指向一表的id字段(JoinColumn)
*@ManyToOne(targetEntity="Author",inversedBy="books")
*@JoinColumn(name="author_id",referencedColumnName="id")
*/
protected $author;
/**
*多对多关系,category和book,JoinTable()加入一个新表进行连接,JoinColumns和inverseJoinClolumns设定新表当中的字段,也可以不设置,
*自动生成,这里需要注意inversedBy和mappedBy,这边用了inversedBy,与之对应的ManyToMany就需要用mappedBy,并且在inversedBy这边JoinTable,
*ManyToMany(targetEntity="Category",inversedBy="books")
*JoinTable(name="books_categories",
*joinColumns={@JoinColumn(name="book_id", referencedColumnName="id")},
*inverseJoinColumns={@JoinColumn(name="category_id", referencedColumnName="id")})
*/
  private $categories;
}
class Category{
/**多对多关系的另一面,使用mappedBy
   *@ManyToMany(targetEntity="Book",mappedBy="categories") 
  */
  private $books;
}

这里基本说明完了三种对应关系,除此之外,由于存在一对多和多对多关系,所以有一些属性是以数组的形式存在的,这里使用ArrayCollection数组比array更高级,可以即时更新(简单理解,具体网上查)

use Doctrine\Common\Collections\ArrayCollection;

这样就需要书写构造函数

public function __construt(){
$this->books = new ArrayCollection();
//其他数组类似
}

接下来第一步构造的表关系就可以进行Entity的定义了,需要注意annoation当中的拼写细节等,可以用doctrine:schema:validate进行验证

4.生成repositoryClass很简单,只需要在entity之前加上annoation即可,这样在执行entities命令时就会自动生成repository文件,以便后续书写该Entity的其他自定义方法

5.生成数据库也很简单,doctrine:schema:update   命令(前面都要加上php app/console)

Doctrine2-完整创建数据库的更多相关文章

  1. Oracle如何实现创建数据库、备份数据库及数据导出导入的一条龙操作

    Oracle中对数据对象和数据的管理,无疑都是使用PL/SQL Developer来进行管理,该工具也提供给我们很多方便.快捷的操作,使得我们不再为Oracle本身丑陋.难用的UI而抱怨.由于我们一般 ...

  2. MongoDB创建数据库和集合命令db.createCollection详解(转)

    切换/创建数据库 use yourDB;  当创建一个集合(table)的时候会自动创建当前数据库 完整的命令如下:db.createCollection(name, {capped: <Boo ...

  3. [转]Oracle如何实现创建数据库、备份数据库及数据导出导入的一条龙操作

    本文转自:http://www.cnblogs.com/wuhuacong/archive/2012/03/09/2387680.html Oracle中对数据对象和数据的管理,无疑都是使用PL/SQ ...

  4. VBS创建数据库

    '创建数据库'参数:strDBPath 字符串型 数据库文件的完整路径Sub CreateDataBase(strDBPath)Dim catObjSet catObj = CreateObject( ...

  5. sql2008 计划自动创建数据库分区【转】

    本文转自:http://jingyan.baidu.com/article/6b97984d9a26ec1ca3b0bf77.html sql2008 计划自动创建数据库分区 固定增量的数据,自动创建 ...

  6. 《Oracle Database 12c DBA指南》第二章 - 安装Oracle和创建数据库(2.2 安装数据库软件)

    当前关于12c的中文资料比较少,本人将关于DBA的一部分官方文档翻译为中文,很多地方为了帮助中国网友看懂文章,没有按照原文句式翻译,翻译不足之处难免,望多多指正. 2.2 安装数据库软件 这部分简短讲 ...

  7. SQLite使用教程4 创建数据库

    http://www.runoob.com/sqlite/sqlite-create-database.html SQLite 创建数据库 SQLite 的 sqlite3 命令被用来创建新的 SQL ...

  8. 【Android】数据库的简单应用——创建数据库

    SQLiteOpenHelper是一个抽象类,要使用它必须写一个类继承它.SQLiteOpenHelper有两个抽象方法onCreate()和onUpgrade(),我们要在类里面重写这两个方法来实现 ...

  9. SQLite 创建数据库(http://www.w3cschool.cc/sqlite/sqlite-create-database.html)

    SQLite 创建数据库 SQLite 的 sqlite3 命令被用来创建新的 SQLite 数据库.您不需要任何特殊的权限即可创建一个数据. 语法 sqlite3 命令的基本语法如下: $sqlit ...

  10. Windows下Oracle创建数据库的3种方式

    1.   Creating a Database with DBCA DatabaseConfiguration Assistant (DBCA) is the preferred way to cr ...

随机推荐

  1. FileZilla-02

    WordPress的权限方案 通常,所有文件应由您的Web服务器上的用户(ftp)帐户拥有,并且应该可由该帐户写入.在共享主机上,文件永远不应归Web服务器进程本身所有(有时这是www,或apache ...

  2. 安装 SIP 服务器

    SIP服务器: OpenSIPS(Open SIP S erver)是SIP服务器的一个成熟的开源实现.OpenSIPS不仅仅是一个SIP代理/路由器,因为它包含应用程序级别的功能.作为SIP服务器的 ...

  3. LOJ #2719. 「NOI2018」冒泡排序(组合数 + 树状数组)

    题意 给你一个长为 \(n\) 的排列 \(p\) ,问你有多少个等长的排列满足 字典序比 \(p\) 大 : 它进行冒泡排序所需要交换的次数可以取到下界,也就是令第 \(i\) 个数为 \(a_i\ ...

  4. MongoDB介绍与安装

    MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的.他支持的数据结构非常松散,是类似 json 的 bson 格式,因此可以存储比较复杂的数据 ...

  5. CRLF在过滤XSS语句后打Cookie方式

    看了很长时间的漏洞奖励计划,学到了不少骚姿势,我觉得这个姿势很不错,总结下写篇文章发出来.针对CRLF漏洞打cookie的方法. 这里不讲概念挖掘方式了,以实战为主: 阅读文章前先参考文章:http: ...

  6. Oracle Database 快捷版 安装 连接

    Oracle Database 快捷版 11g 第 2 版 下载地址:http://www.oracle.com/technetwork/cn/database/database-technologi ...

  7. JMeter 不同线程组间变量传递

    JMeter元件都是有作用域的,而变量大多使用正则表达式提取器,要想在不通过线程组件使用变量参数,则需要设置全部变量 JMeter函数助手就提供了一个函数用于设置全局变量属性,实现的功能类似于在用户自 ...

  8. django系列5:视图

    在Django中,网页和其他内容由视图提供.每个视图都由一个简单的Python函数(或基于类的视图的方法)表示.Django将通过检查所请求的URL(确切地说,是域名后面的URL部分)来选择视图. 在 ...

  9. openstack项目【day23】:云计算介绍(一)

    本节内容 为何选择云计算/云计算之前遇到的问题 什么是云计算 云服务模式 云应用形式 传统应用与云感知应用 一:为何选择云计算/云计算之前遇到的问题 一.有效解决硬件单点故障问题 单点故障是指某个硬件 ...

  10. [Android] Android RxJava2+Retrofit2+OkHttp3 的使用(一) --基础篇 Retrofit2 的使用

    本文是 Android RxJava2+Retrofit2+OkHttp3 的使用(一) --基础篇 Retrofit2 的使用 本文的目标是用 Retrofit写一个网络请求: 本文以从获取天气预报 ...