版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、文章内容组件管理thinkphp视图、关联模型讲师:马明内容组件p视图模型p关联模型 视图模型p定义视图模型,只需要继承viewmodel,然后设置viewfields属性即可。class blogviewmodel extends viewmodel public $viewfields = array( blog=array(id,name,title), category=array(title=category_name, _on=blog.category_id=category.id), user=array(name=username, _on=blog.user_id=user
2、.id), ); 定义视图模型pblog=array(id,name,title)p_as=myblogptitle=category_name p_on=blog.category_id=category.idp_type=left 视图查询p$model = d(blogview);p$model-field(id,name,title,category_name,useruame)-where(id10)-order(id desc)-select();p$model-field(id,name,title,categoryname,username)-order(id desc)-gr
3、oup(id)-select(); 关联模型p关联关系n一对一关联一对一关联 :one_to_one,包括has_one 和 belongs_to n一对多关联一对多关联 :one_to_many,包括has_many 和 belongs_ton多对多关联多对多关联 :many_to_many 关联模型p关联关系必然有一个参照表,例如:n用户表、用户分组表、用户收货地址表、商品表、订单表等n每个用户都有对应的用户资料档案,所以属于has_one关联n每个用户都属于某个用户组,所以属于belongs_to关联n每个用户都可以发表多篇文章,但某个文章只属于一个用户,因此属于has_many关联n每
4、个模块可以属于多个菜单项,一个菜单项内可以包含多个模块,因此属于many_to_many关联 关联定义pthinkphp可以很轻松的完成数据表的关联curd操作,目前支持的关联关系包括下面四种:has_one、belongs_to、has_many、many_to_many。p一个模型根据业务模型的复杂程度可以同时定义多个关联,不受限制,所有的关联定义都统一在模型类的 $_link 成员变量里面定义,并且可以支持动态定义。要支持关联操作,模型类必须继承relationmodel类,关联定义的格式是:protected $_link = array( 关联1 = array( 关联属性1 = 定
5、义, 关联属性n = 定义, ), 关联2 = array( 关联属性1 = 定义, 关联属性n = 定义, ), .); 关联模型has_onephas_one关联表示当前模型拥有一个子对象,例如,每个用户都有对应的用户资料档案。我们可以建立一个用户模型usermodel,并且添加如下关联定义:class usermodel extends relationmodelpublic $_link = array( profile= has_one,);p上面是最简单的方式,表示其遵循了系统内置的数据库规范,完整的定义方式是:class usermodel extends relationmod
6、el public $_link = array( profile=array( mapping_type =has_one, class_name =profile, / 定义更多的关联属性 ), ); belongs_topbelongs_to 关联表示当前模型从属于另外一个父对象,例如每个用户都属于一个部门。我们可以做如下关联定义。class categorymodel extends relationmodel public $_link = array(section = array(mapping_type = belongs_to,class_name = section,for
7、eign_key = sectionid,mapping_name = section,/as_fields = title:section_title,),); has_manyphas_many 关联表示当前模型拥有多个子对象,例如每个用户有多篇文章,我们可以这样来定义class usermodel extends relationmodel public $_link = array(article = array(mapping_type = has_many,class_name = article,foreign_key = created_by,mapping_name = article,mapping_order=created desc,/as_fields = title,alias:art_alias,),); many_to_manypmany_to_many 关联表示当前模型可以属于多个对象,而父对象则可能包含有多个子对象,通常两者之间需要一个中间表类约束和关联。例如每个用户可以属于多个组,每个组可以有多个用户:class usermodel extends relationmodel public $_link = array(“group = array( mapping_type=many_to_many, class
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五年度生态农业园区场地租赁及农产品销售合同3篇
- 二零二五年度出国定居文化体验与活动组织合同4篇
- 2025年鲁教版必修2物理上册月考试卷
- 2025劳动合同法无故旷工
- 2025室内装饰装修合伙合作合同
- 2025年度电器产品节能补贴申请与使用合同4篇
- 2025翡翠买卖合同书
- 业务外包合作协议 完整版
- 2025年车辆配件生产厂股权转让及销售渠道合作协议4篇
- 2025年度瓷砖产品线上展示与虚拟现实销售合同3篇
- 杜仲叶药理作用及临床应用研究进展
- 4S店售后服务6S管理新规制度
- 高性能建筑钢材的研发与应用
- 无线广播行业现状分析
- 汉语言沟通发展量表(长表)-词汇及手势(8-16月龄)
- 高速公路相关知识讲座
- 儿科关于抗生素使用的PDCA
- 商务服务业的市场细分和定位策略
- 财政学论文我国财政支出存在的问题及改革建议
- 小学生必备古诗
- 手术室护理实践指南2023年
评论
0/150
提交评论