
50版本和之前版本的差异较大,本篇对熟悉32版本的用户给出了一些50的主要区别。 URL和路由 50的URL访问不再支持普通URL模式,路由也不支持正则路由定义,而是全部改为规则路由配合变量规则(正则定义)的方式: 主要改进如下; 增加路由变量规则; 增加组合变量支持; 增加资源路由; 增加路由分组; 增加闭包定义支持; 增加MISS路由定义; 支持URL路由规则反解析; 请求对象和响应对象 50新增了请求对象Request和响应对象Response,Request统一处理请求和获取请求信息,Response对象负责输出客户端或者浏览器响应。 模块和控制器 控制器的命名空间有所调整,并且可以无需继承任何的控制器类。 应用命名空间统一为app(可定义)而不是模块名; 控制器的类名默认不带Controller后缀,可以配置开启use_controller_suffix参数启用控制器类后缀; 控制器 *** 作方法采用return方式返回数据 而非直接输出; 废除原来的 *** 作前后置方法; 增加beforeActionList属性定义前置 *** 作; 支持任意层次的控制器定义和访问; URL访问支持自动定位控制器; 数据库 50的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过Db类调用,原来的M函数调用可以改用db函数,例如: 32版本 M('User')->where(['name'=>'thinkphp'])->find(); 50版本 db('User')->where('name','thinkphp')->find(); 主要改进如下: 支持链式查询 *** 作; 数据查询支持返回对象、数组和PDOStatement对象; 数据集查询支持返回数组和Collection对象; 增加查询构造器,查询语法改变; 支持闭包查询; 支持分块查询; 支持视图查询; 增加SQL监听事件; 模型 50的模型变化是最大的,基本上模型是完全面向对象的概念,包括关联模型,模型类的后缀不再带Model,直接由命名空间区分,原来的D函数调用改为model函数,并且必须创建对应的模型类,例如: 32版本 D('User')->where(['name'=>'thinkphp'])->find(); 50版本 model('User')->where('name','thinkphp')->find(); 主要改进包括: 重构关联模型; 支持聚合模型; 废除视图模型(改为数据库的视图查询方法); 模型的扩展采用Trait机制; 增加获取器和修改器; 增加时间戳自动写入; 增加类型字段转换; 数组访问支持; JSON序列化支持; 自动验证和自动完成 50的数据自动验证和自动完成和32版本区别较大,50的数据验证采用验证器定义并且通过think\Validate类进行统一的验证。自动完成则通过在模型里面定义修改器来完成。 异常 50对错误零容忍,默认情况下会对任何级别的错误抛出异常(但可以在应用公共文件中设置错误级别),并且重新设计了异常页面,展示了详尽的错误信息,便于调试。 调试和日志 50的页面Trace强化,支持浏览器控制台查看Trace信息。 50的日志驱动增加Socket方式,采用SocketLog支持远程调试。 常量 50版本废弃了原来的大部分常量定义,仅仅保留了框架的路径常量定义,其余的常量可以使用App类或者Request类的相关属性或者方法来完成,或者自己重新定义需要的常量。 废除的常量包括: REQUEST_METHOD IS_GET IS_POST IS_PUT IS_DELETE IS_AJAX __EXT__ COMMON_MODULE MODULE_NAME CONTROLLER_NAME ACTION_NAME APP_NAMESPACE APP_DEBUG MODULE_PATH 函数 50版本核心框架不依赖任何自定义函数,但仍然封装了一些常用功能到助手函数,你可以随意重新定义或者增加助手函数。
不用的哈,用什么PHP框架,就要多看这个框架的手册。
>
就如此题来说,你传递过来的id值,就是表的主键。
pid一般是为父键的意思,$catemodel->where('pid=%d',$_GET['id'])->select();
查询的是这个id所对应子集的。
楼上所说这种,有点曲解楼主的意思。楼主的意思,估计就是子集没数据的缘故。
1、从index页面的最新动态链接到event页面,要想显示右边栏,最简单的方法就是将超链接直接指向event页面,就像导航栏“动态”一样
2、但是你需要传递最新动态的eventID,所以event()函数应该增加接收eventID的内容
3、另外,你显示页面默认显示数据的方法getContentBy2()可以删除,将其内容整合到event()函数中,参考第2点,如果接收到eventID,说明是通过index的最新动态链接过来的,没接收到eventID则是直接访问的
综上所述,我给出event()函数的大致内容
public function event(){
// 你原先的内容
// 以下新增内容
$eventID = I("eventID",0,"intval"); // 读取eventID,不存在则默认为0
if($eventID){
// 存在,即从index的最新动态链接过来
// 你原先index控制器getContent()函数的内容,注意display()那行就不要了
} else {
// 不存在eventID,即直接访问的,那就显示默认内容
// 也就是你原先getContentBy2()函数的内容,注意不用ajax返回,采用assign()赋值即可
}
}
相应的,前台需要修改的有:
①index页面最新动态的超链接
②删除event页面getContentBy2()的js代码
方法:
$time=strtotime($_POST['dates']);//dates为从文本框获得的日期
$sql='select from think_mytask where strtotime(starttime)<=$time and strtotime(endtime)>=$time';
$admin1=new Model('mytask');
$list=$admin1->query($sql);
如果是mysql里面两个不同的数据库,应该是可以直接使用 [数据库名称][表名]来关联的。TP指定的数据库,是因为他要缓存这个数据库的表字段等。
试试看行不行,我测试通过: SELECT a,b FROM table1 a LEFT JOIN db2table2 b ON aid=bid
参考示例如下,并注意count的用法,不要乱用。是求次数?还是求和?根据需求 *** 作。
-- cts:每一行pid出现的次数
SELECT FLOOR((CHAR_LENGTH(cart_data)-CHAR_LENGTH(REPLACE(cart_data,"pid","")))/3)'cts' from tbs;
如果你只是希望得到不重复的[2015,2016,2017]这样的数据,那你可以直接先把createTime的字段遍历出来,tp我记得也是有遍历数组的方法,然后用strstr(‘0’,‘4’,$arr),在循环中将这些字段值只保留前4位,然后依次写入数组,在加个判断,如果数组中存在相同元素,如已经有了2015,就不在写入
所以说,我不大清楚你的意图
以上就是关于thinkphp3.2以上版本 怎么获取数据主键全部的内容,包括:thinkphp3.2以上版本 怎么获取数据主键、ThinkPHP中查询数据库where()中的条件必须包含主键值吗、用thinkphp做添加,跳转页即提示成功又提示模版不存在,但查数据库是添加了等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)