ThinkPHP视图查询详解
ThinkPHP视图查询详解
ThinkPHP提供的视图查询应用功能十分强大,用户利用视图查询功能可以将多个数据表的字段内容按需要进行指定和筛选,组织成一个基于这些数据表的视图模型,然后就可以通过该模型直接进行多表联合查询,非常方便和简单。
例如在项目中,我们定义有三个表:
user 用户基础表,
user_info 用户详细信息表,
dept 部门分类表
现在我们需要获取某个用户信息,
该信息要包括用户的帐号名称和相关资料与及所在部门的名称,
这时候我们可以利用视图查询进行处理。
下面举例加以说明:
1.构建一个新项目并进行相关配置(可参考前面的教程,这里省略)
2.创建一个数据库tpview,并添加这三个表
(1) 用户表
1
2
3
4
5
6
7
8
9
10
|
CREATE TABLE `think_user` ( `id` int (11) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID编号' , ` name ` varchar (20) NOT NULL COMMENT '帐户' , ` password ` varchar (32) NOT NULL COMMENT '密码' , `dept_id` smallint (6) unsigned NOT NULL , `status` tinyint(1) unsigned NOT NULL DEFAULT '1' COMMENT '开放状态' , PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT= '会员表' AUTO_INCREMENT=2 ; INSERT INTO `think_user` (`id`, ` name `, ` password `, `dept_id`, `status`) VALUES (1, 'zzguo28' , '123456' , 2, 1); |
(2)用户信息表
1
2
3
4
5
6
7
8
9
10
11
12
|
CREATE TABLE `think_user_info` ( `user_id` int (11) NOT NULL COMMENT '用户id' , `nick_name` varchar (30) NOT NULL COMMENT '用户昵称' , `email` varchar (100) NOT NULL COMMENT '邮箱地址' , `address` varchar (100) NOT NULL COMMENT '详细地址' , `gender` tinyint(1) NOT NULL DEFAULT '0' COMMENT '性别' , `mobile` varchar (100) NOT NULL COMMENT '手机号码' , `telephone` varchar (100) NOT NULL COMMENT '电话号码' , KEY `user_id` (`user_id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT= DYNAMIC COMMENT= '用户信息表' ; INSERT INTO `think_user_info` (`user_id`, `nick_name`, `email`, `address`, `gender`, `mobile`, `telephone`) VALUES (1, '国' , 'zzguo28@163.com' , 'TP路think街1.6号' , 1, '12345678901' , '123456' ); |
(3) 部门分类表
1
2
3
4
5
6
7
8
9
|
CREATE TABLE `think_dept` ( `id` smallint (3) NOT NULL AUTO_INCREMENT, ` name ` varchar (50) NOT NULL , PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=4 ; INSERT INTO `think_dept` (`id`, ` name `) VALUES (1, '开发部' ), (2, '销售部' ), (3, '财务部' ); |
3.在项目/Lib/Model下创建这三个表的基础模型Model
本示例没涉及到验证等其它功能,所以只要简单定义测可,例如
1
2
3
4
|
<?php class UserModel extends Model { } ?> |
其实视图模型对应的数据表并非一定要有相应的的基础模型,但是建议您创建,这样单表和视图都可以操作。
4.创建视图模型,代码如下,详细注解见其后:
(附注:最新svn上已增加动态扩展模型功能,使用新版需要将protected属性改为public属性,建议使用动态扩展功能去使用视图查询,而不再是本教程的继承方式。那样使用会更灵活。)
1
2
3
4
5
6
7
8
9
10
|
<?php import( 'ViewModel' ); class UserViewModel extends ViewModel{ protected $viewFields = array ( 'User' => array ( 'id' , 'name' , '_as' => 'u' , '_type' => 'left' ), 'UserInfo' => array ( 'email' , 'mobile' , '_as' => 'ui' , '_on' => 'ui.user_id=u.id' ), 'Dept' => array ( 'name' => 'dept' , '_on' => 'u.dept_id=Dept.id' ), ); } ?> |
对上述代码解释如下:
在第2行代码中,由于自TP1.6版开始已将视图查询分离出原Model类,因此这里需要使用import方法引入了视图模型类。
第3行代码中,定义了该模型名称为UserViewModel,视图模型的名称Model前的命名是随意的,只是为了有别于其它模型,通常我们会以xxxViewModel这样的方式去命名。并且一定要继承ViewModel。(ThinkPHP1.6版无需再设置模型的viewModel属性为true,只要继承ViewModel则可)
第4行代码$viewFields 属性表示视图模型包含的字段,每个元素定义了各个数据表或者模型所需的字段。
格式是
1
2
3
|
protected $viewFields = array ( '表名' => array ( '所需字段' , '_as' => '别名定义' , '_on' => '筛选条件' , '_type' => '指定join类型,支持right,inner,left三种' ), ); |
注意到第7行代码中的'name'=>'dept',因为User模型里面已经存在了一个name字段,所以我们通过这种方式把Dept模型的name字段映射为dept字段,如果有多个字段,可以使用同样的方式添加。
定义完毕后,我们在Action中进行测试,代码如下
1
2
3
4
5
6
7
8
9
10
|
<?php class IndexAction extends Action{ public function index(){ $dao = D( 'UserView' ); $where [ 'u.id' ] = 1; dump( $dao ->where( $where )->find()); dump( $dao ->getLastSql()); } } ?> |
然后访问该操作,可以看到我们成功取得所需的查询内容:
1
2
3
4
5
6
7
8
9
|
array (1) { [0] => array (5) { [ "id" ] => string(1) "1" [ "name" ] => string(7) "zzguo28" [ "email" ] => string(17) "zzguo28@163.com" [ "mobile" ] => string(11) "12345678901" [ "dept" ] => string(9) "销售部" } } |
并可以看到使用的sql如下
1
|
"SELECT u.id AS id,u.name AS name,ui.email AS email,ui.mobile AS mobile,Dept.name AS dept FROM think_user u LEFT JOIN think_user_info ui ON ui.user_id=u.id JOIN think_dept Dept ON u.dept_id=Dept.id WHERE ( u.id = 1 ) LIMIT 1 " |
视图模型在查询上和普通单表并没有多大分别,可以使用我们所熟悉的各种连贯操作,例如order,limit等等。
ThinkPHP视图查询详解的更多相关文章
- Lucene系列六:Lucene搜索详解(Lucene搜索流程详解、搜索核心API详解、基本查询详解、QueryParser详解)
一.搜索流程详解 1. 先看一下Lucene的架构图 由图可知搜索的过程如下: 用户输入搜索的关键字.对关键字进行分词.根据分词结果去索引库里面找到对应的文章id.根据文章id找到对应的文章 2. L ...
- ElasticSearch第四步-查询详解
ElasticSearch系列学习 ElasticSearch第一步-环境配置 ElasticSearch第二步-CRUD之Sense ElasticSearch第三步-中文分词 ElasticSea ...
- Solr安装入门、查询详解
Solr安装入门:http://www.importnew.com/12607.html 查询详解:http://www.360doc.com/content/14/0306/18/203871_35 ...
- MySQL简单查询详解-单表查询
MySQL简单查询详解-单表查询 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.查询的执行路径 一条SQL查询语句的执行过程大致如下图所示: 1>.客户端和服务端通过my ...
- (转)Mysql 多表查询详解
MySQL 多表查询详解 一.前言 二.示例 三.注意事项 一.前言 上篇讲到mysql中关键字执行的顺序,只涉及了一张表:实际应用大部分情况下,查询语句都会涉及到多张表格 : 1.1 多表连接有 ...
- 【转载】D3DXMatrixLookAtLH视图变换函数详解
原文:D3DXMatrixLookAtLH视图变换函数详解 /*D3DXMatrixLookAtLH函数返回的是世界->视图变换矩阵. 视图坐标系和局部坐标系是一样的,都是世界坐标系转换为指定的 ...
- 分享知识-快乐自己:Hibernate 中Criteria Query查询详解
1):Hibernate 中Criteria Query查询详解 当查询数据时,人们往往需要设置查询条件.在SQL或HQL语句中,查询条件常常放在where子句中. 此外,Hibernate还支持Cr ...
- ThinkPHP视图查询
ThinkPHP视图查询 一.总结 1.这里的视图查询和多表查询很像,当然多表查询的话肯定要支持左右链接查询 2.view:视图的使用,关键字是view 3.sql视图功能支持:thinkphp支持视 ...
- Mysql高手系列 - 第12篇:子查询详解
这是Mysql系列第12篇. 环境:mysql5.7.25,cmd命令中进行演示. 本章节非常重要. 子查询 出现在select语句中的select语句,称为子查询或内查询. 外部的select查询语 ...
随机推荐
- html img Src base64 图片显示
http://blog.csdn.net/knxw0001/article/details/10983605 大家可能注意到了,网页上有些图片的src或css背景图片的url后面跟了一大串字符,比如: ...
- python - socket模块1
1.使用生活中的接打电话,解释socket通信流程 2.根据上图,写出socket通信的伪代码 2.1.server端伪代码 #买手机 #买手机卡 #开机 #等待电话 #收消息 #发消息 #挂电 ...
- 技术路线 vs 技术管理路线
最近因为要给刚毕业的学生做一次演讲,所以就职业发展这类话题先以写博客的形式做一些思考,希望届时能给同学们带来质量更高的内容.我在<驾驭你的"职场布朗运动">一文中谈了2 ...
- Oracle游标cursor2显示的游标等
--在一中我们介绍了实现过程 select *from stud; declare cursor mycur is select id,name from stud;--1声明 v_id intege ...
- oracle 数据库 if...elsif...语句
CREATE OR REPLACE FUNCTION "UFN_GETIDS" ( OPEKIND IN VARCHAR2,-- 查询类型 PARAMS IN ...
- Mysql常用命令记录
-- 导出数据库: mysqldump -u user_name -p database_name > import_file.sql -- 执行脚本 source database.sql
- (二)backbone - DEMO - user list
Demo介绍 学习了如何基本的使用Backbone,展示用户信息 使用JQuery操作DOM,backbone.localStorage.js操作localstorage 大体实现 •创建user M ...
- c++ 编译期计算 (一)
编译期就是编译器进行编译,产生.obj文件的所处的那一段时间(如果是广义的编译期,那么一般还包括了链接期,因为现在很多编译器都会自动调用链接器进行链接)执行期就是你执行某个已经链接好的程序的那段时间. ...
- Java如何获取当前的jar包路径以及如何读取jar包中的资源
写作业的时候要输出一个record.dat文件到jar包的同级目录,但是不知道怎么定位jar包的路径.百度到的方法不很靠谱,所以在这里记录一下. 一:使用类路径 String path = this. ...
- jade的基本语法
- for (var i=0;i<3;i++) li scnu-learn //这里的=,默认会转义内容 p= "Welcome scnu <strong>good< ...