基于TP框架SQL之where与having区别

本文详细介绍了ThinkPHP框架中create方法的功能与使用流程,包括数据对象生成、字段合法性检测、自动验证等特性,帮助开发者更好地掌握数据处理技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下载链接http://download.youkuaiyun.com/detail/qq_35461287/9678066



1. where 子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,条件中不能包含聚组函数,使用where条件显示特定的行。

2. having 子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用having 条件显示特定的组,也可以使用多个分组标准进行分组。

 

项目中多次用到create() 只能它是表单验证,不过好出错,痛下心扉好好了解理解它的来龙去脉和所用的用法

一:通过create() 方法或者 赋值的方法生成数据对象,然后写入数据库

1 $model = D('User');

2 $model->create();  //略过具体的自动生成和验证判断

3 $model->add()

1create()方法还支持其他方式创建数据对象:如,其他的数据对象或者数组

 1 $data['name'] = 'Mike'; 2 $data['sex'] = 'male'; 3 $user->create($data); 

2: 创建完成的数据可以直接读取和修改

3: create的第二个操作方法可以指定创建数据的操作状态,默认是自动判断是写入还是更新操作

4: 如果没有定义自动验证的话,create方法返回值是创建完成的数据对象数组

5create方法创建的数据对象时保存在内存中,并没有实际写入到数据库中,直到使用add或则save方法才会真正写入到数据库

二:用于写入:field()create()结合使用,检测字段的合法性(表单提交)

 1 $model->field('title,email,content')->create(); 

    合法字段只有title,email,content,无论用户通过什么手段添加其他字段都会屏蔽掉。

三:自动验证,是模型层提供的一种数据验证方法,create创建数据对象的时候自动进行数据验证:具体分为静态和动态方式

 

四:create() 在创建数据对象的同时,完成一系列的工作,工作流程

        步骤       

                                    说明                                            

     返回          

1

获取数据源(默认是POST数组)

 

2

验证数据源合法性(非数组或者对象会过滤)

失败返回false

3

检查字段映射

 

4

判断数据状态(新增或者编辑,指定或者自动判断)

 

5

数据自动验证

失败返回false

6

表单令牌验证

失败返回false

7

表单数据赋值(过滤非法字段和字符串处理)

 

8

数据自动完成

 

9

生成数据对象(保存在内存)

 

 

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

钟长森

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值