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每个方法的意思,不然你可能一不小心就会 ...
随机推荐
- [C]排序并插入
/* 编写程序,在主函数中定义一个有10个元素的整型一维数组,用户输入9个数据,调用函数,对数组元素进行从小到大排序后,在函数中输入一个数,插入到数组中正确的位置,并输出. */ #include&l ...
- linux下禁用网卡的启用网卡的一些方法
第一种方法: 这种方法主要是在不重启的情况下会一直生效,适用于服务器. #禁用网卡eth0 sudo ifconfig eth0 down #启用网卡eth0 sudo ifconfig eth0 u ...
- MySQL出现too many connections(1040)错误解决方法
https://www.cnblogs.com/2881064178dinfeng/p/6938112.html 其实MySQL默认的最大连接数为100,可能在大访问量的时候造成了连接不上数据库.解决 ...
- java 大数运算[转]
用JAVA 实现算术表达式(1234324234324 + 8938459043545)/5 + 343434343432.59845 因为JAVA语言中的long 定义的变量值的最大数受到限制,例如 ...
- maven无法下载oracle驱动包
由于版权问题,在中央仓库是没有oracle的jdbc驱动的,可以手动下载到本地或者在oracle安装目录的jdbc目录中找到对应的jar,然后通过以下命令安装到本地仓库 mvn install:ins ...
- day05-数据类型与操作
- cpu工作原理
- windows 时间服务器配置详解
最近发现公司的服务器时间一直不准确,也无法和外部时间源进行同步.公司是域环境,按理说客户端PC应该自动和域控AD进行时间同步,但是PC机时间老是不能同步,不是慢了就是快了,就是和域控时间不一致.其它服 ...
- thymeleaf的fragment例子
fragment介绍 fragment类似于JSP的tag,在html中文件中,可以将多个地方出现的元素块用fragment包起来使用. 定义fragment 新建foot.html文件 <!D ...
- C#控制台下测试多线程的源码
下边代码是关于C#控制台下测试多线程的的代码,应该是对小伙伴有所用. class Program { static void Main(string[] args) { ThreadStart num ...