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() 展现标签对应名称
标签名称与模型属性对应
【商品添加逻辑部分】
在控制器我们接收表单数据
商品添加
制作表单
收集表单数据,收集好的数据给予数据模型
数据模型调用save方法,实现数据添加
【数据修改】
获得被修改的数据-----》展现到一个表单里边(呈现被修改数据的)-------》在表单里边针对具体内容进行修改-------》修改完毕提交表单进行数据的更新
修改商品信息,我们使用的模板是添加时候的模板,基本没有改动,form表单使用小物件构建的,这个小物件会自动把关联的信息给显示出来,节省了我们开发的成本,这也是我们使用小物件创建form表单的原因之一。
还有一个使用小物件的原因是表单验证需要使用小物件。
同样是save()方法被调用,有insert语句或update语句区分。
new Goods() 和 Goods::model()
都可以进行查询
前者主要是在添加的时候使用,后者是在查询或修改的时候使用。
如果我们添加数据,不使用new Goods,而使用Goods::model那么数据添加失败。
【商品信息删除】
【数据查询延伸】
AR(CActiveRecord)活跃记录
find() 查询一个信息
findByPk 根据主键查询信息
findBySql根据sql语句查询信息
findAll()查询全部信息
findAllByPk 根据主键查询全部信息
findAllBySql根据sql语句查询全部信息
findBySql 和 findAllBySql
根据sql语句查询信息,前者会查询一条记录信息,后者会查询条记录信息
前者给返回一个数据模型对象,后者以数组形式给我们返回多个数据模型对象
select * from goods limit 10
findByPk 和 findAllByPk
都是根据主键进行信息的查询
前者每次只可以传递一个主键信息,后者可以传递一个也传递多个
后者传递参数,如果是多个主键信息,需要以数组形式给我们传递。
select condition order limit offset 都是从哪来的。
我们使用findAll() 该方法是数据模型给我们封装好的方法,可以获得全部数据
findAll()是CactiveRecord这个类的成员方法。AR是对数据库向上的封装,AR通过OOP面向对象方式操作数据库。AR需要最终转变为具体的sql语句,通过一个中间类(criteria标准)协助转为的具体sql语句,上边的关键字就是这个中间类criteria的一些属性。
内容总结
1. 商品添加逻辑部分完成(save())
2. 商品信息修改,通过widget小物件创建的表单可以用在添加和修改两个地方。
通过get方式传递被修改商品信息id,同时在控制器方法里边有参数接收
3. 删除商品信息 delete
删除和修改信息,需要注意是那个模型对象调用方法。
4. 详细介绍数据查询和中间标准类 criteria讲解