重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

关于php5.0模型查询数据的信息

ThinkPHP 5.0和ThinkPHP 3.2的区别?

URL和路由

灵石网站建设公司成都创新互联公司,灵石网站设计制作,有大型网站制作公司丰富经验。已为灵石数千家提供企业网站建设服务。企业网站搭建\外贸网站建设要多少钱,请找那个售后服务好的灵石做网站的公司定做!

5.0的URL访问不再支持普通URL模式,路由也不支持正则路由定义,而是全部改为规则路由配合变量规则(正则定义)的方式:

主要改进如下:

1.增加路由变量规则;

增加组合变量支持;

增加资源路由;

增加路由分组;

增加闭包定义支持;

增加MISS路由定义;

支持URL路由规则反解析;

2.请求对象和响应对象

5.0新增了请求对象Request和响应对象Response,Request统一处理请求和获取请求信息,Response对象负责输出客户端或者浏览器响应。

3.废除原来的操作前后置方法;

增加beforeActionList属性定义前置操作;

支持任意层次的控制器定义和访问;

URL访问支持自动定位控制器;

4.数据库

5.0的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过Db类调用,原来的M函数调用可以改用db函数,例如:

3.2版本

M('User')-where(['name'='thinkphp'])-find();

5.0版本

db('User')-where('name','thinkphp')-find();

5.自动验证和自动完成

5.0的数据自动验证和自动完成和3.2版本区别较大,5.0的数据验证采用验证器定义并且通过think\Validate类进行统一的验证。自动完成则通过在模型里面定义修改器来完成。

6.异常

5.0对错误零容忍,默认情况下会对任何级别的错误抛出异常(但可以在应用公共文件中设置错误级别),并且重新设计了异常页面,展示了详尽的错误信息,便于调试.

thinkphp5.0进行数据字段乘除操作怎么做?

如果要用thinkphp查询出一张表的所有数据,可以这样来做: 假设数据表的表名为:think_table1,这里think_ 是表前缀(包含下滑线)。 thinkphp内置了M函数,可以这样实例化think_table1这张表: M('table1') , 因为think_这个前缀名称在配置文...

ThinkPHP 5.0和ThinkPHP 3.2的区别

5.0版本和之前版本的差异较大,本篇对熟悉3.2版本的用户给出了一些5.0的主要区别。

URL和路由

5.0的URL访问不再支持普通URL模式,路由也不支持正则路由定义,而是全部改为规则路由配合变量规则(正则定义)的方式:

主要改进如下;

增加路由变量规则;

增加组合变量支持;

增加资源路由;

增加路由分组;

增加闭包定义支持;

增加MISS路由定义;

支持URL路由规则反解析;

请求对象和响应对象

5.0新增了请求对象Request和响应对象Response,Request统一处理请求和获取请求信息,Response对象负责输出客户端或者浏览器响应。

模块和控制器

控制器的命名空间有所调整,并且可以无需继承任何的控制器类。

应用命名空间统一为app(可定义)而不是模块名;

控制器的类名默认不带Controller后缀,可以配置开启use_controller_suffix参数启用控制器类后缀;

控制器操作方法采用return方式返回数据 而非直接输出;

废除原来的操作前后置方法;

增加beforeActionList属性定义前置操作;

支持任意层次的控制器定义和访问;

URL访问支持自动定位控制器;

数据库

5.0的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过Db类调用,原来的M函数调用可以改用db函数,例如:

3.2版本

M('User')-where(['name'='thinkphp'])-find();

5.0版本

db('User')-where('name','thinkphp')-find();

主要改进如下:

支持链式查询操作;

数据查询支持返回对象、数组和PDOStatement对象;

数据集查询支持返回数组和Collection对象;

增加查询构造器,查询语法改变;

支持闭包查询;

支持分块查询;

支持视图查询;

增加SQL监听事件;

模型

5.0的模型变化是最大的,基本上模型是完全面向对象的概念,包括关联模型,模型类的后缀不再带Model,直接由命名空间区分,原来的D函数调用改为model函数,并且必须创建对应的模型类,例如:

3.2版本

D('User')-where(['name'='thinkphp'])-find();

5.0版本

model('User')-where('name','thinkphp')-find();

主要改进包括:

重构关联模型;

支持聚合模型;

废除视图模型(改为数据库的视图查询方法);

模型的扩展采用Trait机制;

增加获取器和修改器;

增加时间戳自动写入;

增加类型字段转换;

数组访问支持;

JSON序列化支持;

自动验证和自动完成

5.0的数据自动验证和自动完成和3.2版本区别较大,5.0的数据验证采用验证器定义并且通过think\Validate类进行统一的验证。自动完成则通过在模型里面定义修改器来完成。

异常

5.0对错误零容忍,默认情况下会对任何级别的错误抛出异常(但可以在应用公共文件中设置错误级别),并且重新设计了异常页面,展示了详尽的错误信息,便于调试。

调试和日志

5.0的页面Trace强化,支持浏览器控制台查看Trace信息。

5.0的日志驱动增加Socket方式,采用SocketLog支持远程调试。

常量

5.0版本废弃了原来的大部分常量定义,仅仅保留了框架的路径常量定义,其余的常量可以使用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

函数

5.0版本核心框架不依赖任何自定义函数,但仍然封装了一些常用功能到助手函数,你可以随意重新定义或者增加助手函数。

Thinkphp5.0 为什么有的数据表可以查询,有的查询不了?

提示 dbs.user表不存在

看看是数据库名错了还是表名错了或多加了表前缀

怎样试用PHP原生语句查询数据库

原生SQL查询有 query() 和 execute() 两个方法:

query():用于 SQL 查询操作,并返回符合查询条件的数据集

execute():更新和写入数据的 SQL 操作,返回影响的记录数

query()

query() 方法是用于 SQL 查询操作,和select()方法一样返回符合查询条件的数据集。

例子:

public function read(){

// 实例化一个空模型,没有对应任何数据表

$Dao = M();

//或者使用 $Dao = new Model();

$list = $Dao-query("select * from user where uid5");

if($list){

$this-assign('list', $list );

$this-display();

} else {

$this-error($Dao-getError());

}

}

对于 query() 方法返回的数据集,跟 select() 一样,可以在模板里直接循环输出。

execute()

execute() 方法用于更新和写入数据的 SQL 操作(注:非查询操作,无返回数据集),返回影响的记录数。

例子:

public function read(){

header("Content-Type:text/html; charset=utf-8");

// 实例化一个空模型,没有对应任何数据表

$Dao = M();

//或者使用 $Dao = new Model();

$num = $Dao-execute("update user set email = '12345@xxx.com' where uid=3");

if($num){

echo '更新 ',$num,' 条记录。';

}else{

echo '无记录更新';

}

}

如果查询比较复杂或一些特殊的数据操作不能通过 ThinkPHP 内置的 ORM 和 ActiveRecord 模式实现时,就可以通过直接使用原生 SQL 查询来实现。

注意:以上都是 user 没有表前缀的例子,在查询语句中,查询的表应该写实际的表名字(包括前缀)。

thinkphp 5.0 是不是 // 数据库表前缀 失效了

Thinkphp可以使用数据库表前缀的。

在database.php文件中设置prefix属性即可。

(以上截图来源于Thinkphp官方文档)

设置了前缀以后。使用方法举例如下:

假设设置的前缀是think_,我们要连接的数据表是name。

1、数据库方式:

D('name')-select(); //查询think_name数据表的全部数据。

2、模型方式:

model('name')-select(); //默认情况下,查询think_name数据表的全部数据。

模型还有其他实例化或者静态调用的方式,你可以直接查看官方文档。


网站标题:关于php5.0模型查询数据的信息
分享网址:http://cqcxhl.cn/article/dscpsgs.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP