博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
thinkPHP视图模型详解,把mysql表关联简单化!
阅读量:5940 次
发布时间:2019-06-19

本文共 2762 字,大约阅读时间需要 9 分钟。

   学过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,
  
`
name
varchar
(200) 
default 
NULL
,
  
`title` 
varchar
(200) 
default 
NULL
,
  
`category_id` tinyint(4) 
default 
NULL
,
  
`
user
varchar
(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,
  
`
name
varchar
(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,如需转载请自行联系原作者
你可能感兴趣的文章
RH124 章1 访问命令行 笔记
查看>>
交换机自动学习vlan
查看>>
三层交换配置与原理
查看>>
Nginx ssl、rewrite配置
查看>>
ORA-01034: ORACLE not available ORA-27101
查看>>
“九头虫”病毒技术分析报告
查看>>
共享经济时代,中小企业该如何逆风翻盘?
查看>>
axios 一些用法总结
查看>>
jQuery中的$el是什么意思
查看>>
千万不要相信程序员在加班时间写的代码!
查看>>
部队军工VR虚拟仿真应用-VR虚拟作战系统-VR公安系统
查看>>
下载ssl证书并安装后如何导出备份
查看>>
rpc.ratatd安装过程中遇到的问题
查看>>
word导出功能
查看>>
验证码不显示,如何进入phpcms管理后台
查看>>
创建topic验证kafka集群
查看>>
我的友情链接
查看>>
linux top 命令
查看>>
vsftp421问题
查看>>
Python学习笔记4—Python字典元组
查看>>