Tp框架之模型层
数据模型层是专门针对数据库来操作的
我们在home模块用一下数据模型层
先把配置修改好
我们先来打开这个文件

然后再打开think里面的主配置,把那里面关于数据库的部分,复制到home下的配置文件,然后进行修改

复制后再粘贴

拿过来之后就可以对这些数据进行修改了

数据库和密码都是输入自己的
然后在think里面的配置文件里还有特别重要的一项

把它复制下来

粘贴到这里
把那个true改成false

在操作数据库的时候尽量把字段缓存关掉
如果启用的话,它就会有缓存,当我们对数据库进行操作,比如删除、或增加的话,数据可能不会改变的那么快
我们把这些配置做好后,就可以对数据库操作了
先来做一个模型层
在这里新建一个文件

名字也要根据约定来
里面先简单的写上内容

然后在Main配置文件里
输出一下

运行一下,找ceshi页面

输出了很多条数据
除了new方法还有其他的方法
D方法也可以

运行后

结果是一样的
也是去实例化一个模型对像
除了这两种方式,还有一种快捷方法,也是tp框架带的一种方法,M方法

运行后

上面的地方有点不一样,直接造的是父类对象
M方法造的是你父类对象,上面两种造的是子类对象,在对数据访问的时候,这三种方式都可以,访问的结果都是一模一样的
再来看怎么从数据表中操作数据
还是在Main控制器里写

然后刷新页面运行一下,看看有没有把数据都输出来

返回的是二维数组,而且是关联数组
在写数据库的时候,在创建表的时候尽量是小写
再来看第二个方法

给了它一个值,让它根据p001来找
刷新页面运行一下,看看能不能找到

返回了一个一维数组,这个一维数组包含了一条数组
find方法就是根据主键值来查找一条数据
再来试试用select方法能不能根据主键值来查找数据

刷新页面,运行一下

可以查到,但查到的还是二维数组
select方法里面不仅可以写一个参数,也就是说它可以查多条数据

刷新页面,运行一下

find只能查一条
select能查多条
再来说一下连贯操作
还是以info数据为例

这样返回的是对象,需要给它加个条件才能转为数据

后面加上select方法
刷新页面运行一下

p001找到了
所以说这个where就是条件查询

在里面随便写条件,用or隔开,多个条件是可以的
我们可以在配置文件里,加上一句话

然后刷新页面,就可以把那个小图标调出来了

可以点开查看一下Sql语句

这是我们说的第一个连贯操作,where语句
第二个连贯操作是table方法
---恢复内容结束---
数据模型层是专门针对数据库来操作的
我们在home模块用一下数据模型层
先把配置修改好
我们先来打开这个文件

然后再打开think里面的主配置,把那里面关于数据库的部分,复制到home下的配置文件,然后进行修改

复制后再粘贴

拿过来之后就可以对这些数据进行修改了

数据库和密码都是输入自己的
然后在think里面的配置文件里还有特别重要的一项

把它复制下来

粘贴到这里
把那个true改成false

在操作数据库的时候尽量把字段缓存关掉
如果启用的话,它就会有缓存,当我们对数据库进行操作,比如删除、或增加的话,数据可能不会改变的那么快
我们把这些配置做好后,就可以对数据库操作了
先来做一个模型层
在这里新建一个文件

名字也要根据约定来
里面先简单的写上内容

然后在Main配置文件里
输出一下

运行一下,找ceshi页面

输出了很多条数据
除了new方法还有其他的方法
D方法也可以

运行后

结果是一样的
也是去实例化一个模型对像
除了这两种方式,还有一种快捷方法,也是tp框架带的一种方法,M方法

运行后

上面的地方有点不一样,直接造的是父类对象
M方法造的是你父类对象,上面两种造的是子类对象,在对数据访问的时候,这三种方式都可以,访问的结果都是一模一样的
再来看怎么从数据表中操作数据
还是在Main控制器里写

然后刷新页面运行一下,看看有没有把数据都输出来

返回的是二维数组,而且是关联数组
在写数据库的时候,在创建表的时候尽量是小写
再来看第二个方法

给了它一个值,让它根据p001来找
刷新页面运行一下,看看能不能找到

返回了一个一维数组,这个一维数组包含了一条数组
find方法就是根据主键值来查找一条数据
再来试试用select方法能不能根据主键值来查找数据

刷新页面,运行一下

可以查到,但查到的还是二维数组
select方法里面不仅可以写一个参数,也就是说它可以查多条数据

刷新页面,运行一下

find只能查一条
select能查多条
再来说一下连贯操作
还是以info数据为例

这样返回的是对象,需要给它加个条件才能转为数据

后面加上select方法
刷新页面运行一下

p001找到了
所以说这个where就是条件查询

在里面随便写条件,用or隔开,多个条件是可以的
我们可以在配置文件里,加上一句话

然后刷新页面,就可以把那个小图标调出来了

可以点开查看一下Sql语句

这是我们说的第一个连贯操作,where语句
第二个连贯操作是table方法
之前写了一遍数据都没了,这次就不一一演示了,太费时间了
最后那个去重field是哪一列的意思如果不写这个的话,它会对所有数据进行去重操作
Tp框架之模型层的更多相关文章
- TP框架---Model模型层---做模型对象
TP框架----Model模型层---------------做模型对象 Model模型层是用来做什么的呢???? 主要是用来做操作数据库访问的. 也就说明TP框架自带了一种访问数据库的方式,使用的是 ...
- tp框架-----Model模型层
1.Model模型层是用来做什么的呢? 主要是用来做操作数据库访问的.也就说明TP框架自带了一种访问数据库的方式,使用的是Model模型. 2.Model模型怎样使用呢? 要使用Model模型层访问数 ...
- TP框架---thinkphp模型
1.获取系统常量信息的方法:在控制器DengLuController里面下写入下面的方法,然后调用该方法. public function test() { //echo "这是测试的&qu ...
- tp框架---View视图层---模板继承(举例说明)
当我们做动态页面时,我们会发现一个网站的头部和尾部是相同的,那么我们如何用tp框架来做模板呢 ? 先看一下注意事项: (1)每个区块由<block></block>标签组成 ( ...
- TP框架 基础1
php框架 一.真实项目开发步骤: 多人同时开发项目,协作开发项目.分工合理.效率有提高(代码风格不一样.分工不好) 测试阶段 上线运行 对项目进行维护.修改.升级(单个人维护项目,十分困难,代码风格 ...
- TP框架---thinkphp基础知识
php框架 发瑞 一.真实项目开发步骤: 多人同时开发项目,协作开发项目.分工合理.效率有提高(代码风格不一样.分工不好) 测试阶段 上线运行 对项目进行维护.修改.升级(单个人维护项目,十分困 ...
- TP框架基础(三)
[系统常量信息] 获取系统常量信息: 如果加参数true,会分组显示: >系统常量信息里经常用到的是user里的路径 > APP_PATH =>string'./shop/' 项目路 ...
- Django基础模型层(77-78)
jango框架之模型层(d77-78)一 单表操作: 1 mysql数据库:settings里配置 'default': { # key值必须都是大写 'ENGINE': 'django.d ...
- tp框架数据查询,增删改
select()是数据模型的一个指定方法,可以获得数据表的数据信息 返回一个二维数组信息,当前数据表的全部数据信息 $obj = D(); 创建对象 $obj -> select(); 查询 ...
随机推荐
- JavaScript 44 Puzzlers
http://mp.weixin.qq.com/s?__biz=MzAxODE2MjM1MA==&mid=2651550987&idx=1&sn=f7a84b59de14d0b ...
- Flex移动应用程序开发的技巧和窍门(一)
这是一个由多个部分组成的系列文章的第一部分,它包含了Flex移动开发的若干技巧.如果你过去习惯于桌面和Web编程,你会发现,开发移动应用程序将面临一系列新的挑战. 除了重新思考你的对数据存储和处理的策 ...
- SQLSERVER如何导入数据保持ID不变(ID为自增主键)
使用SQL SERVER最操蛋的就是导入数据,以前用企业管理器直接导数据,导一次骂N次娘,在骂了微软无数次娘之后总结了一个方法揍合着还算受用. 其核心要点就是要将数据结构导入到目标数据库服务器上,再来 ...
- EntityFramework Core 1.1有哪些新特性呢?我们需要知道
前言 在项目中用到EntityFramework Core都是现学现用,及时发现问题及时测试,私下利用休闲时间也会去学习其他未曾遇到过或者用过的特性,本节我们来讲讲在EntityFramework C ...
- js事件对象
哎,事件也有对象呦.程序员一直在讲对象对象,那么,过年是不是该带个对象回家呢?好了,既然事件有对象,承认这个事实吧!哈哈,那么,其就有属性,接下来,就放个 例子来讲讲,顺便把常用的属性也添加进去.. ...
- ACM 刷题小技巧【转】
转载自URl-team ACM做题过程中的一些小技巧. 1.一般用C语言节约空间,要用C++库函数或STL时才用C++; cout.cin和printf.scanf最好不要混用. 大数据输入输出时最好 ...
- [CSS3] 学习笔记-选择器详解(三)
1.UI元素状态伪类选择器 在CSS3的选择器中,除了结构性伪类选择器外,还有一种UI元素伪类选择器.这些选择器的共同特征是:指定的样式只有当元素处于某种状态时才起作用,在默认状态下不起作用.在CSS ...
- Biztalk AS2开发经验总结
一. 准备证书 4 1. 升级win2008 R2证书服务 4 2. 申请证书 6 二. 配置证书 13 1. 为AS2配置证书 13 2. ...
- 使用jsCompress压缩混淆js代码的一些常见的问题和技巧
不同的团队使用的js混淆器或压缩工具不一样,jsCompress是一款绿色的免费的js压缩工具,时代定制的UI团队推荐大家使用,不仅性能优越,而且操作非常人性化. 使用jsCompress.exe时, ...
- Windows Container 和 Docker:你需要知道的5件事
微软在2016年的Ignite技术大会上正式发布了Windows Server 2016,其中的容器服务已经可以作为生产环境使用.这意味着Windows 内置的容器服务正式进入了大家的视野,虽然之前我 ...