Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

模型model

关于商品的数据模型goods  model  MVC

利用商品模型实现数据的查询和添加

查询:

findAll()

find()

findBySql

 

findAll() 该查询系列帮助我们获得多条数据,以数组形式给我们返回,数组里边的每个元素都是一个模型对象。获得具体数据需要遍历。

find() 该查询系列帮助我们每次只获得一条数据,以模型对象的形式给我们返回。

 

我们使用模型model步骤:

1. 创建模型对象

① 模型名字::model()  

② new  模型模型()

2. 利用对象调用模型里边的一些方法,实现对数据的操作

 

【商品数据添加】

现在我们已经把添加的表单展现出来,widget小物件展示的表单。

表单展现:

model

attributeLabels()  模型属性与汉字标签名字对应

controller

将模型传递到视图里边

view(小物件 widget)

CactiveForm

textField()  普通输入框

label()  展现标签对应名称

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

标签名称与模型属性对应

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

【商品添加逻辑部分】

 

在控制器我们接收表单数据

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

商品添加

制作表单

收集表单数据,收集好的数据给予数据模型

数据模型调用save方法,实现数据添加

 

 

【数据修改】

获得被修改的数据-----》展现到一个表单里边(呈现被修改数据的)-------》在表单里边针对具体内容进行修改-------》修改完毕提交表单进行数据的更新

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

修改商品信息,我们使用的模板是添加时候的模板,基本没有改动,form表单使用小物件构建的,这个小物件会自动把关联的信息给显示出来,节省了我们开发的成本,这也是我们使用小物件创建form表单的原因之一。

还有一个使用小物件的原因是表单验证需要使用小物件。

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

同样是save()方法被调用,有insert语句或update语句区分。

 

new  Goods()  Goods::model()  

都可以进行查询

前者主要是在添加的时候使用,后者是在查询或修改的时候使用。

如果我们添加数据,不使用new Goods,而使用Goods::model那么数据添加失败。

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

【商品信息删除】

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

【数据查询延伸】

AR(CActiveRecord)活跃记录

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

find() 查询一个信息

findByPk 根据主键查询信息

findBySql根据sql语句查询信息

findAll()查询全部信息

findAllByPk 根据主键查询全部信息

findAllBySql根据sql语句查询全部信息

 

findBySql findAllBySql

根据sql语句查询信息,前者会查询一条记录信息,后者会查询条记录信息

前者给返回一个数据模型对象,后者以数组形式给我们返回多个数据模型对象

select  *  from  goods  limit 10

 

findByPk findAllByPk  

都是根据主键进行信息的查询

前者每次只可以传递一个主键信息,后者可以传递一个也传递多个

后者传递参数,如果是多个主键信息,需要以数组形式给我们传递。

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

select  condition   order   limit   offset 都是从哪来的。

 

我们使用findAll() 该方法是数据模型给我们封装好的方法,可以获得全部数据

findAll()CactiveRecord这个类的成员方法。AR是对数据库向上的封装,AR通过OOP面向对象方式操作数据库。AR需要最终转变为具体的sql语句,通过一个中间类(criteria标准)协助转为的具体sql语句,上边的关键字就是这个中间类criteria的一些属性。

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

内容总结

1. 商品添加逻辑部分完成(save())

2. 商品信息修改,通过widget小物件创建的表单可以用在添加修改两个地方。

通过get方式传递被修改商品信息id,同时在控制器方法里边有参数接收

3. 删除商品信息 delete

删除和修改信息,需要注意是那个模型对象调用方法。

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

Yii框架之增删改查、yii_newGoods和Goodsmodel区别代码追踪、数据模型criteria延伸讲解

4. 详细介绍数据查询和中间标准类 criteria讲解