开发者社区> 余二五> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

thinkPHP视图模型详解,把mysql表关联简单化!

简介:
+关注继续查看

   学过sql的人都知道有表左关联,右关联,但是sql语句要写很多,非常容易出错,而ThinkPHP的视图模型则简单化很多了。还发现个问题,貌似ThinkPHP手册写的很多东西都不是很完善,很多人看了都不懂。如果有什么不懂的,可以加群:252799167交流,或者给我留言,今天就写个ThinkPHP的视图模型小例子,让大家知道该怎么用。

   mysql的表关联其实就是将多个表的数据联系到一起,然后临时生成一张表,方便读取数据。而在ThinkPHP中视图表同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。    

   接下来开始创建表gl_blog:

1
2
3
4
5
6
7
8
9
10
11
12
13
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for `gl_blog`
-- ----------------------------
DROP TABLE IF EXISTS `gl_blog`;
CREATE TABLE `gl_blog` (
  `id` int(11) NOT NULL auto_increment,
  `namevarchar(200) default NULL,
  `title` varchar(200) default NULL,
  `category_id` tinyint(4) default NULL,
  `uservarchar(200) default NULL,
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;



gl_category

1
2
3
4
5
6
7
8
9
10
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for `gl_category`
-- ----------------------------
DROP TABLE IF EXISTS `gl_category`;
CREATE TABLE `gl_category` (
  `id` int(11) NOT NULL auto_increment,
  `title` varchar(200) default NULL,
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


gl_user

1
2
3
4
5
6
7
8
9
10
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for `gl_user`
-- ----------------------------
DROP TABLE IF EXISTS `gl_user`;
CREATE TABLE `gl_user` (
  `id` int(11) NOT NULL auto_increment,
  `namevarchar(200) default NULL,
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


   新建入口文件,生成项目文件,设置编码为utf-8(可以根据自己的需要来)

在Model文件夹里新建BlogViewModel.class.php

内容:

1
2
3
4
5
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.id'),   );}


'Blog'=>array('id','name','title');

Blog表中要显示的字段,和数据表相对应

'title'=>'category_name',

给Category表中的title定义别名为category_name,如果不想可以不定义

'_on'=>'Blog.category_id=Category.id'

'_on'将两个表建立联系,也就是Blog表中的category_id和Category中的id字段相对应,如果Category表中有多哥要显示的字段,可以直接array('title'=>'category_name',在array中添加即可,


还有几种用法,

array('title'=>'category_name'   指定表名

'_as'=>'myBlog'        给当前的数据表定义别名

'_type'=>'LEFT'        左关联还是右关联


至于User表和Blog表建立的联系,就不说了,大家应该都能看懂了。



写完了下来就是使用的了

在IndexAction.class.php写

1
$Model = D("BlogView");$Model->field('id,name,title,category_name,username')->where('id>10')->order('id desc')->select();



初始化BlogView视图模型的类,查询id,name,title,category_name,username字段,条件id大于10,降序排列



   是不是非常简单?呵呵。学了ThinkPHP有两个月了,发现ThinkPHP非常的人性化,尽量去简化很多操作,不过可能有些会额外的增加开销。这个可以在精通ThinkPHP以后,根据自己项目条件不同,去适当修改优化ThinkPHP,推荐如果想学习ThinkPHP的朋友可以去研究研究ThinkSNS的例子,非常不错










本文转自 3147972 51CTO博客,原文链接:http://blog.51cto.com/a3147972/1228482,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
【MySQL】你还不会在Docker下安装MySQL主备吗?
那什么时候就要开始考虑搭建主备架构呢, 一方面是随着业务增长,读写请求已经到达了一定的瓶颈时,我们需要考虑,另一方面为了保证数据的完整性,以保证主宕机的时候,可以快速切换。
7 0
mysql安装记录
mysql安装记录
8 0
MySQL安装+配置
首先在MySQL官网上下载安装包Mysql官网下载 解压后选择合适的安装路径一路next安装
8 0
Linux 使用rpm方式安装最新mysql(5.7.22)步骤以及常见问题解决
Linux 使用rpm方式安装最新mysql(5.7.22)步骤以及常见问题解决
8 0
Linux安装MYSQL 并使用图形化界面连接
Linux安装MYSQL 并使用图形化界面连接
25 0
MySql的详细安装说明
MySql的详细安装说明
24 0
Docker 安装 MySQL | 学习笔记
快速学习 Docker 安装 MySQL
14 0
+关注
文章
问答
文章排行榜
最热
最新
相关电子书
更多
MySQL表和索引优化实战
立即下载
MySQL 5.7优化不求人
立即下载
MySQL 5.7让优化更轻松
立即下载