ThinkPhp框架:分页查询和补充框架知识
上一篇的随笔写的是基本操作,现在可以做一些高级操作,例如有条件的查询数据,有分页的条件查询数据
一、一个条件的查询数据
查询数据自然是先要显示出数据,然后根据条件进行查询数据
(1)显示出表的数据
这个方法我还是写在了HomeController.class控制器文件中
(1.1)写了一个方法shouye()
1
2
3
4
5
6
7
|
public function shouye() { $n = M( "nation" ); //数据库中的表 $arr = $n ->select(); //查询表中的所有数据 $this ->assign( "shuju" , $arr ); //将二维数组注入变量 $this ->show(); //显示数据 } |
(1.2)方法写完了之后,下面就是写显示页面了,这个名字和方法名一致
这里我们用表格来显示一下数据
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
<table width= "50%" border= "1" cellpadding= "0" cellspacing= "0" > <tr> <td>代号</td> <td>名称</td> <td>操作</td> </tr><br> <!--注意:这里的循环没有{}这是和smarty模板的区别--> < foreach name= "shuju" item= "v" > <!--参数name是php页面中的注入的名字,item是赋值的量--> <tr> <td>{ $v .code}</td> <!--这就是显示的code列--> <td>{ $v .name}</td> <!--这是显示的name列--> <td>操作</td> </tr> </ foreach > </table> |
下面运行看下效果:注意地址栏的书写:http://localhost/tp/index.php/Home/Home/shouye
(2)添加查询条件
(2.1)这样的话就要添加查询的文本框和查询按钮了,我们添加在表的前面
这里用表单来写,因为提交嘛,所以用表单进行写
1
2
3
4
5
6
|
< form action="__ACTION__" method="post"> < div > 根据名称查询:< input type="text" name="name" /> < input type="submit" value="查询"/> </ div > </ form > |
看下显示效果
(2.2)显示出来之后,就是后面的处理页面了
这个查询和添加、修改的逻辑处理方式还不一样,这里就不用if判断了
1
2
3
4
5
6
7
8
9
10
11
12
13
|
public function shouye() { $tj = " 1=1 " ; //条件恒成立 if (! empty ( $_POST [ "name" ])) //判断传过来的name值是不是空的 { $name = $_POST [ "name" ]; $tj = " Name like '%{$name}%' " ; //修改$tj的值 } $n = M( "nation" ); $arr = $n ->where( $tj )->select(); //因为是tp框架,所以直接可以调用这个条件,用where()方法 $this ->assign( "shuju" , $arr ); $this ->show(); } |
这样运行一下,然后查看一下结果
查询一下“回”的信息,可以实现这个查询
(2.3)可以在这个查询中添加分页,也就是分页的显示
1.这里我们引用一下以前写过的page分页的类,先把这个page的类放到自己的模块下面,我放在了这里
打开这个类文件,修改一下命名空间如下所示:
然后关闭就可以了。
2.在shouye()方法中调用Page类
2.1首先要调用这个page类
2.2这个类要有两个参数:分页的总条数,显示的条数
1
|
$page = new \Home\shuju\page( $zts ,2); //第一个参数:数据总条数;第二个参数是显示几条 |
2.3总条数:查询也是要显示总条数
1
|
$zts = $n ->where( $tj )-> count (); //总条数也要包括查询 |
2.4在limit这里要对源文件,进行修改
1
|
$page ->limit; //LIMIT 10,3 |
这样的话会多着个limit,那么在page.class.php源文件中删除就可以
2.5查询所有条件时加上这个limit($page->limit)方法
1
|
$arr = $n ->where( $tj )->limit( $page ->limit)->select(); |
2.6注入变量(将分页的信息显示信息注入)
1
|
$this ->assign( "fenye" , $page ->fpage()); //page的fpage分页的显示信息 |
看下总的这个shouye()的方法,上面的综合
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
public function shouye() { $tj = " 1=1 " ; if (! empty ( $_POST [ "name" ])) { $name = $_POST [ "name" ]; $tj = " Name like '%{$name}%' " ; } $n = M( "nation" ); $zts = $n ->where( $tj )-> count (); //总条数也要包括查询 $page = new \Home\shuju\page( $zts ,2); //第一个参数:数据总条数;第二个参数是显示几条 //$page->limit; //LIMIT 10,3 $arr = $n ->where( $tj )->limit( $page ->limit)->select(); //这是显示的分页 $this ->assign( "shuju" , $arr ); //注入变量(总的数据的) $this ->assign( "fenye" , $page ->fpage()); //注入变量(分页的显示信息) $this ->show(); } |
2.7在显示页面,显示这个变量
1
|
< div >{$fenye}</ div > |
看先运行结果,是有了分页信息
但是这样有个缺陷,就是在查询一个条件时,第一条是显示的总条数是正确的额,但是后面的是错误的,那么就是要修改代码
注意:将数据的传输方式修改(post修改为get)
3.查询的文本框显示默认值
这里在条件恒成立下,定义一个name值为空,然后在注入变量
在显示页面的文本框的中,添加value值是前面注入的变量
注意:
1.看下完整的php页面的代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
public function shouye() { $tj = " 1=1 " ; $name = "" ; if (! empty ( $_POST [ "name" ])) { $name = $_POST [ "name" ]; $tj = " Name like '%{$name}%' " ; } $n = M( "nation" ); $zts = $n ->where( $tj )-> count (); //总条数也要包括查询 $page = new \Home\shuju\page( $zts ,2); //第一个参数:数据总条数;第二个参数是显示几条 //$page->limit; //LIMIT 10,3 $arr = $n ->where( $tj )->limit( $page ->limit)->select(); //这是显示的分页 $this ->assign( "shuju" , $arr ); //注入变量(总的数据的) $this ->assign( "fenye" , $page ->fpage()); //注入变量(分页的显示信息) $this ->assign( "name" , $name ); //将name的值注入变量 $this ->show(); } |
2.显示页面的整体内容
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
< form action="__ACTION__" method="get"> < div > 根据名称查询:< input type="text" name="name" value="{$name}"/> < input type="submit" value="查询"/> </ div > </ form > < br /> < table width="50%" border="1" cellpadding="0" cellspacing="0"> < tr > < td >代号</ td > < td >名称</ td > < td >操作</ td > </ tr > < foreach name="shuju" item="v" > < tr > < td >{$v.code}</ td > < td >{$v.name}</ td > < td >操作</ td > </ tr > </ foreach > </ table > < div >{$fenye}</ div > |
这样总的效果就已经结束了
进行查询后,文本框显示查询的名字,显示的条数也是会变换的
二、数据取值方式
1.写一个方法,来进行数据的传值差别:正常的GET方式取值
1
2
3
4
|
public function testget() { echo $_GET [ "name" ]; } |
在浏览器的地址栏地址中输入:
(1)后面是:?名称="值"
1.没有传值的话是空
http://localhost/tp/index.php/Home/Home/testget
输出就是空的:
2.有值的传值
http://localhost/tp/index.php/Home/Home/testget?name=%22%E4%BD%A0%E5%A5%BD%22
这样就会输出:你好
(2)后面是路径的方式:/名称/值
地址栏中输入:
http://localhost/tp/index.php/Home/Home/testget/name/qqqqqq
输出结果
注意:传多值就是/名字/值/名字/值
2.给方法赋值的方式取值
1
2
3
4
|
public function testget( $code ) { echo $code ; } |
三、session方法和cookie方法
(1)session方法
1.默认情况下,初始化之后系统会自动启动session,如果不希望系统自动启动session的话,可以设置SESSION_AUTO_START
为false,例如:
1
|
'SESSION_AUTO_START' =>false |
关闭自动启动后可以项目的公共文件或者在控制器中通过手动调用session_start
或者session('[start]')
启动session。
2.session赋值
1
|
session( 'name' , 'value' ); //设置session |
3.session判断
1
2
|
// 判断名称为name的session值是否已经设置 session( '?name' ); |
4.session管理
1
2
3
4
|
session( '[pause]' ); // 暂停session写入 session( '[start]' ); // 启动session session( '[destroy]' ); // 销毁session session( '[regenerate]' ); // 重新生成session id |
(2)cookie方法
Cookie设置
1
2
|
cookie( 'name' , 'value' ); //设置cookie cookie( 'name' , 'value' ,3600); // 指定cookie保存时间 |
四、模板(三元运算)
模板可以支持三元运算符
1
2
|
{ $status ? '正常' : '错误' } { $info [ 'status' ]? $info [ 'msg' ]: $info [ 'error' ]} |
注意:三元运算符中暂时不支持点语法。
五、AJAX返回
要使用ajax就要引用jQuery了,我们把jQuery拿进来
(1)我放到了Public文件夹下,新建一个js文件夹下
(2)然后就是在显示的页面调出这个js文件
1
|
< script src="__PUBLIC__/js/jquery-1.11.2.min.js"></ script > |
(3)看下这个文件是不是引入了
在浏览器的地址栏中输入:http://localhost/tp/index.php/Home/Home/shouye
查看源代码查看是不是引入了
点开之后要是能够出现就是引入成功了
(4)在控制器中写一个方法chuli,让ajax返回这个方法
1
2
3
4
|
public function chuli() { } |
(5)就要写ajax了
1
2
3
4
5
6
7
8
9
10
|
< script type="text/javascript"> $.ajax({ url:"__CONTROLLER__/chuli", //处理方法的 dataType:"TEXT", success: function(data){ //成功之后的输出的信息 } }) </ script > |
(6)在chuli方法页面就要写返回值了
1
2
3
4
|
public function chuli() { $this ->ajaxReturn( "hello" , "eval" ); //返回的值,返回值的方式eval就是text方式 } |
注意:如果是JSON/JSONP格式,会自动编码成JSON字符串,如果是XML方式,会自动编码成XML字符串,如果是EVAL方式的话,只会输出字符串data数据。
完整的显示页面的代码:
1
2
3
4
5
6
7
8
9
10
|
< script type="text/javascript"> $.ajax({ url:"__CONTROLLER__/chuli", dataType:"TEXT", success: function(data){ alert(data); //返回的信息 } }) </ script > |
看下效果:
也可以是关联数组的数据,就不写了
六、跳转和重定向
(1)页面跳转
使用方法很简单
1
2
3
4
5
6
7
8
9
10
|
$User = M( 'User' ); //实例化User对象 $result = $User ->add( $data ); if ( $result ){ //设置成功后跳转页面的地址,默认的返回页面是$_SERVER['HTTP_REFERER'] $this ->success( '新增成功' , 'User/list' ); } else { //错误页面的默认跳转页面是返回前一页,通常不需要设置 $this ->error( '新增失败' ); } |
注意:success和error方法的第一个参数表示提示信息,第二个参数表示跳转地址,第三个参数是跳转时间(单位为秒)
1
2
3
4
|
// 操作完成3秒后跳转到 /Article/index $this ->success( '操作完成' , '/Article/index' ,3); // 操作失败5秒后跳转到 /Article/error $this ->error( '操作失败' , '/Article/error' ,5); |
注意:跳转地址是可选的,success方法的默认跳转地址是$_SERVER["HTTP_REFERER"]
,error方法的默认跳转地址是javascript:history.back(-1);
。
这就是tp框架的另外的一些知识和操作
ThinkPhp框架:分页查询和补充框架知识的更多相关文章
- ThinkPhp框架分页查询和部分框架知识
一.一个条件的查询数据 查询数据自然是先要显示出数据,然后根据条件进行查询数据 (1)显示出表的数据 这个方法我还是写在了HomeController.class控制器文件中 (1.1)写了一个方法s ...
- 使用PetaPoco ORM 框架分页查询
通过在派生的Repository中调用GetPagingEntities方法来获取分页数据,并返回由PagingDataSet<T>封装分页集合,例如: Public PagingData ...
- 分享自研实现的多数据源(支持同DB不同表、跨DB表、内存数据、外部系统数据等)分页查询工具类实现原理及使用
思考: 提起分页查询,想必任何一个开发人员(不论是新手还是老手)都能快速编码实现,实现原理再简单不过,无非就是写一条SELECT查询的SQL语句,ORDER BY分页排序的字段, 再结合limit ( ...
- ThinkPhp框架 分页 和session验证的使用
TP框架分页要使用到类文件,可以使用自己的类文件,也可以使用tp框架自带的类文件. 首先导入分页的类文件(Page.class.php): <?php namespace Home\shuju; ...
- (补充)10.Hibernate框架的查询方式
技术分析之Hibernate框架的查询方式 1. 唯一标识OID的检索方式 * session.get(对象.class,OID) 2. 对象的导航的方式 3. HQL的检索方式 * Hibernat ...
- tp框架使用心得(六)——分页查询
http://baijiahao.baidu.com/s?id=1578482537511010805&wfr=spider&for=pc 在用thinkphp中,对于新手手册中还是有 ...
- hibernate框架学习第六天:QBC、分页查询、投影、数据加载策略、二级缓存
QBC查询 1.简单查询 Criteria c = s.createCriteria(TeacherModel.class); 2.获取查询结果 多条:list 单挑:uniqueResult 3.分 ...
- mybatis 框架 的应用之二(批量添加、实现分页查询)
lf-driver=com.mysql.jdbc.Driver lf-url=jdbc:mysql://localhost:3306/test lf-user=LF lf-password=LF &l ...
- Java_Web三大框架之Hibernate+jsp+HQL分页查询
分页查询无处不在.使用Hibernate+jsp+HQL进行分页查询. 第一步:编写房屋实体类和House.hbm.xml映射. /* * 房屋实体类 */ public class House { ...
随机推荐
- MysqlRouter 实现mysql5.6读写分离
下载,安装 [root@localhost src]# cd /usr/local/src/ [root@localhost src]# wget http://dev.mysql.com/get ...
- 【WPF】如何获取命令行参数
应用程序以 Main 方法为入口点,如果为 Main 方法指定一个 string[] 类型的参数,在程序运行时,这个参数会获取到传递给应用程序的命令行参数. 而 WPF 应用程序比较特殊,因为在VS中 ...
- MyBatis7:MyBatis插件及示例----打印每条SQL语句及其执行时间
Plugins 摘一段来自MyBatis官方文档的文字. MyBatis允许你在某一点拦截已映射语句执行的调用.默认情况下,MyBatis允许使用插件来拦截方法调用 Executor(update.q ...
- MVC4加载zTree树小控件
前言: 第一次学习使用MVC框架,找了个练手项目,加载zTree树小控件.下面我就一步步说明我这次练手的经历以记录.如果有什么错误,希望各位大神帮忙指正,谢谢. 第一步: 利用VS2010新建一个MV ...
- 重温Android中的消息机制
引入: 提到Android中的消息机制,大家应该都不陌生,我们在开发中不可避免的要和它打交道.从我们开发的角度来看,Handler是Android消息机制的上层接口.我们在平时的开发中只需要和Hand ...
- DataTables warning (table id = 'DataTables_Table_0');错误解决办法!
这个错误是table表格引起的,我是将条件语句和<td>标签做了调整后,消除的,个人认为是数据缺失引起的.
- IDEA报错处理:Application Server was not connected before run configuration stop, reason: Unable to ping server at localhost:8080
把wildfly的整个软件包更换成新的,配置文件重新配置,JBOSS_HOME环境变量修改成新的,在wildfly-10.1.0.FinalForTest\modules\system\layers\ ...
- c++课程设计之菜单选择
a) 从键盘输入n个数,选择升序还是降序输出 b)创新了日历 c) 添加了射箭游戏 d)还加入了好玩的24点游戏 学生签名: 年 月 日 课程设计(论文)评阅意见 等 级 项 ...
- sqlserver isnull判断
--在新增或编辑的时候设置默认值或加isnull判断 Sql isnull函数 ISNULL(columName, 0)<>35 或 ISNULL(columName, '')<&g ...
- Mysql按时间段分组查询
Mysql按时间段分组查询来统计会员的个数,mysql个数 Mysql按时间段分组查询来统计会员的个数,mysql个数 1.使用case when方法(不建议使用)- 代码如下 复制代码SELECT ...