Laravel--查询构造器 方法 及聚合函数
controller内内容如下
<?php
/**
* Created by PhpStorm.
* User: work
* Date: 2018/1/2
* Time: 20:36
*/
namespace App\Http\Controllers;
use App\Student\Student;
use Illuminate\Support\Facades\DB;
Route::any('query1','StudentController@query1');查询构造器方法 添加方法
public function query1()
{
// 返回布尔 单个添加$bloon = DB::table('student')->insert(['name'=>'gwz','age'=>18]);
// 返回当前添加行 $num = DB::table('student')->insertGetId(['name'=>'ggg','age'=>3]);
// 批量添加返回布尔 $bloon = DB::table('student')->insert([
// ['name'=>'gwz1','age'=>11],
// ['name'=>'gwz22','age'=>111],
// ]);
}
Route::any('query2','StudentController@query2');查询构造器方法 修改方法
//查询构造器方法 修改方法
public function query2()
{
// 影响的行数 $num = DB::table('student')->where(['id'=>5])->update(['age'=>0]);
// 修改年龄增加
// 受影响行数 默认修改年龄数自增为 age=age+1 $num = DB::table('student')->increment('age');
// 受影响行数 默认修改年龄数自增为 age=age+3 $num = DB::table('student')->increment('age',3);
//修改年龄减小
// 受影响行数 默认修改年龄为age=age-1 $num = DB::table('student')->decrement('age');
// 受影响行数 默认修改年龄为age=age-3 $num = DB::table('student')->decrement('age',3);
//受影响行数 id为5 年龄 age=age+3 同时修改`name`为hahahah $num = DB::table('student')->where(['id'=>5])->increment('age',3,['name'=>'hahahah']);
// var_dump($num);
}
Route::any('query3','StudentController@query3');查询构造器方法 删除方法
//查询构造器方法 删除方法
public function query3()
{
// 返回受影响行数 删除条件为 id = 5 $num = DB::table('student')->where('id','5')->delete();
// 返回受影响行数 删除条件为 id >= 5 $num = DB::table('student')->where('id','>=','5')->delete();
//清空表 truncate 非常危险 不返回任何 DB::table('student')->truncate();
}
Route::any('query4','StudentController@query4');查询构造器 查询方法
//查询构造器 查询方法
public function query4()
{
// 主要方法有 get() first() where() pluck() select()
// 获取数据get()
// 获取所有数据 $student = DB::table('student')->get()->toArray();
// 没什么卵用first()
// 获取倒序ID的第一条ID $student = DB::table('student')->orderBy('id','desc')->first();
//
//
// 条件查询where()
// 获取ID大于0的所有数据 并且变为数组 $student = DB::table('student')->where('id','>=',0)->get()->toArray();
// 复合条件查询whereRaw()
// 获取id是11并且年龄是11 并且变为数组 $student = DB::table('student')->whereRaw("id=? and age =?",['11','11'])->get()->toArray();
//pluck()中文意思为摘下的意思 摘下一个字段存为一个数组
// 将字段`name`摘下存入一个数组 $names = DB::table('student')->pluck('name')->toArray();
//pluck()
// 将字段`name`摘下来 数组形式 为 array('id'=>'name') $names = DB::table('student')->pluck('name','id')->toArray();
//select()指定要查询的字段
// 查询`age`,`name`字段内容 且变为二维数组 $student = DB::table('student')->select('age','name')->get()->toArray();
//chunk()用来处理大量数据
// 5.4的不会用暂时不用
// 每次查1000条为一个数组 满足条件则终止查询
// DB::table('student')->chunk(1000,function ($msg){
// var_dump($msg);
// if(你的条件)
// {
// return false;
// }
// });
}
Route::any('query5','StudentController@query5');聚合函数
//聚合函数
public function query5()
{
//统计条数count()
// 表中所有条数 $num = DB::table('student')->count();
//max()取最大
//统计字段中数值最大的 $num = DB::table('student')->max('age');
//min()取最小
//统计字段中数值最小的值 $num = DB::table('student')->min('age');
//avg()
//统计字段中数值平均值 $num = DB::table('student')->avg('age');
//sum()
//统计字段中数值的和
$request->all()//获取所有参数if($request->isMethod('GET')){判断是否是GET请求}$res = $request->is('student/*');$res = $request->ajax();========================================================
laravel 使用 session 路由配置Route::group(['middleware'=>['web']],function (){ Route::any('session1',['uses'=>'StudentController@session1']); Route::any('session2',['uses'=>'StudentController@session2']);});
StudentController 内 存入sessionSession存入数组内方法Sssion::push('key','value1');Sssion::push('key','value2');取出Session中的数组并且删除Session::pull('key');
判断Session中某个Key在不在Session::has('key')public function session1(Request $request) { //HTTP request session(); $request->session()->put('key1','val1');Session::put('key','value'); }
StudentController 内 读取 session public function session2(Request $request) { $session = $request->session()->get('key1');Session::get('key','如果key不存在可以在这里写默认值'); var_dump($session); }
php变量转json public function response() { $data = ['errCode'=>0, 'errMsg'=>'success', 'data'=>'dada' ]; return response()->json($data); }
Laravel--查询构造器 方法 及聚合函数的更多相关文章
- Laravel查询构造器简介
数据表 CREATE TABLE IF NOT EXISTS students( `id` INT AUTO_INCREMENT PRIMARY KEY, `name` VARCHAR(255) NO ...
- Laravel查询构造器的使用方法整理
1.结果集 1.1从一张表获取所有行,get方法获取所有行 $users = DB::table('users')->get(); 获取列的值 foreach ($users as $user) ...
- ORM之自关联、add、set方法、聚合函数、F、Q查询和事务
一.外键自关联(一对多) 1.建表 # 评论表 class Comment(models.Model): id = models.AutoField(primary_key=True) content ...
- hibernate学习系列-----(5)hibernate基本查询下篇:hibernate聚合函数、分组查询及命名查询
在上一篇中,大致学习了hibernate的基本查询:HQL基本查询,今天,继续昨天的步伐,继续学习hibernate的基本查询..... 1.hql聚合函数,先大致列一下hql的聚合函数有哪些吧: 在 ...
- laravel 查询构造器2
//查询构造器 public function query() { //获取所有的数据 $student = DB::table('student')->get(); var_dump($stu ...
- 【mysql】 mysql 子查询、联合查询、模糊查询、排序、聚合函数、分组----------语法
第二章 mysql 一.模糊查询 like 1. 字段 like '河北省%' %代表任何N个字符 2 字段 like '河北省____' _代表任意1个字符 二.IN 语法:SELECT 字段列1, ...
- 第二天,导出文件sql,查询,视图view,聚合函数,反模式,字符串处理函数
//把数据库导出到脚本文件mysqldump -uroot -p1234 --databases abc > d:/a/abc.sql CREATE TABLE stud( id INT PRI ...
- SQL Server温故系列(4):SQL 查询之集合运算 & 聚合函数
1.集合运算 1.1.并集运算 UNION 1.2.差集运算 EXCEPT 1.3.交集运算 INTERSECT 1.4.集合运算小结 2.聚合函数 2.1.求行数函数 COUNT 2.2.求和函数 ...
- laravel查询构造器DB还是ORM,这两者有什么区别,各该用在什么场景中
解答一: 我们所有操作都是走的orm,因为操作简单 直观明了 好维护,性能是低一些 但还没有多致命,真有并发需要优化了 用DB也不一定能解决问题.还是要了解orm每个方法的意思,不然你可能一不小心就会 ...
随机推荐
- centos安装实用总结
1.常用软件安装: yum install -y bash-completion vim lrzsz wget expect net-tools nc nmap tree dos2unix htop ...
- 在qt creator中使用imread并将图片显示到QLable中时没反应
调试时发现Mat m = imread("")函数运行了,但是将鼠标放在m上面时,发现m是空的,但是竟然能往下运行,简直恶心,于是我在后面加上判断m.empty(),发现返回了tu ...
- Linux本地yum源配置以及使用yum源安装gcc编译环境
本文档是图文安装本地yum源的教程,以安装gcc编译环境为例. 适用范围:所有的cetos,红帽,fedroa版本 适用人群:有一点linux基础的小白 范例系统版本:CentOS Linux rel ...
- 删除排序数组中的重复项-leetcode-26
public: int removeDuplicates(vector<int>& nums) { int size=nums.size(); i ...
- centos 终端字体错位个别字母中间有间隔的解决
问题描述: linux系统:centos 终端:图形界面终端,通过startx启动 现象:通过终端输入的字体有重叠,字母之间的间隔也很大.由于字体安装不正确导致. 解决方法:通过下面字体的安装命令可以 ...
- Mysql逆向工程效率神器之使用IDE自动生成Java实体类
Mysql逆向工程效率神器之使用IDE自动生成Java实体类 简介:实战使用IDE根据Mysql自动生成java pojo实体类 1.IDEA连接数据库 菜单View→Tool Windows→Dat ...
- Oracle的安装+PL安装+系统变量配好后重启
服务启动后的样子 第一步安装oracle服务 链接: https://pan.baidu.com/s/1sRu95Vy1arc3gfuH9nH5Wg 提取码: eaxx 复制这段内容后打开百度网盘手机 ...
- zabbix4.0离线快速编译安装(编译安装方法)
本博客已整理更新至第二版.更新与2019.4.17 其实这个主要是想试一下离线编译安装的具体步骤,记得要配置好本地yum云,因为我们需要使用yum,yum能帮我们自动解决很多依赖问题.发现最主要的问题 ...
- 第二节 Python基础之变量,运算符,if语句,while和for循环语句
我们在上一节中,我们发现当我们用字符串进行一些功能处理的时候,我们都是把整个字符串写下来的,比如"jasonhy".startwith("j"),如果我们在程序 ...
- 批量删除ppt动画
alt+F11打开宏编辑窗口,输入以下代码,运行即可: Sub removeALL() Dim I As Integer: Dim J As Integer Dim oActivePres As Ob ...