laravel5.6 数据库操作-查询构建器

 <?php
//laravel5.6 语法 demo示例 namespace App\Http\Controllers;//命名该控制App空间下名称 use Illuminate\Support\Facades\DB;//使用DB操作数据库
use App\Http\Controllers\Controller;//继承基础控制器 class UserController extends Controller
{
/**
* 展示应用的用户列表.
*
* @return Response
*/
public function index()
{
//DB使用为每种操作提供了相应方法:select(查),update(修改),insert(插入),delete(删除),statement(声明)
//建议占位符,其他框架通用性强
//原生sql写法
$data = DB::select('select * from users where id = :id and name = :name ',[':id' => 1,':name' =>'测试']); //查方法
//get() 方法获取表中所有记录(获取多行多列)
$data = DB::table('users')->get(); //first() 方法将会返回单个对象(获取一行一列)
//where() 方法查询指定条件对象
$data = DB::table('users')->where('id','name','3','测试')->first(); //select() 方法可以查询指定自定义字段
$data = DB::table('users')->select('id','name', 'email')->get(); //value() 方法从结果中获取单个值,该方法会直接返回指定列的值:
$data = DB::table('users')->where('name','测试')->value('email'); //pluck() 方法获取单个列值的数组
$data = DB::table('users')->pluck('name'); //count() 统计数量
$data = DB::table('users')->count(); //exists() 方法来判断匹配查询条件的结果是否存在
$data=DB::table('users')->where('id', 1)->exists(); //join() 方法连表查询
$data = DB::table('users')
->join('ceshi', 'users.id', '=', 'ceshi.id')
->select('users.*', 'ceshi.name')
->get(); //leftJoin() 方法左连表查询
$data = DB::table('users')
->leftJoin('ceshi', 'users.id', '=', 'ceshi.id')
->select('users.*', 'ceshi.name')
->get(); //where() 参数说明:(一)参数是列名,(二)参数是操作符,(三)参数是该列要比较的值
$data = DB::table('users')
->where('id', '>=', 1)
->where('name', 'like', '测试%')
->get(); //传递条件数组到where中写法,建议多where查询使用这个方法
$data = DB::table('users')
->where([
['id', '>=', 1],
['name', 'like', '测试%']
])
->get(); //whereBetween() 方法验证列值是否在给定值之间
$data = DB::table('users')
->whereBetween('id', [1, 3])->get(); //whereIn 方法验证给定列的值是否在给定数组中:
$data = DB::table('users')
->whereIn('id', [1, 2, 3])
->get(); //orderBy() 方法排序
$data = DB::table('users')
->orderBy('id', 'desc')
->get(); //insert() 方法插入记录到数据表
//insertGetId() 方法插入记录并返回自增ID值
$data=DB::table('users')->insert(
[
'name'=>'测试',
'email' => 'ceshi.com',
'password' => 'ceshi'
]
); //update() 方法修改记录
$data =DB::table('users')
->where('id', 1)
->update(['name' => '测试']); //delete() 方法删除记录
$data=DB::table('users')->where('id', '>', 10)->delete(); //paginate() 方法分页 每页显示数量
//注意:目前使用 groupBy 的分页操作不能被Laravel有效执行
$data = DB::table('users')->paginate(2); //前台分页中链接附加参数实现分页
$getName = $GET['name']?:'';
$data = DB::table('users')
->select('id','name','age')
->where('name', 'like', $getName.'%')
->paginate(2); //返回给前端视图数据
return $this->view('index',['data'=>$data,'namePage'=>$getName]); //前端引用代码
//appends 方法添加查询参数到分页链接查询字符串; 添加 &name=$namePage到每个分页链接中.
{{ $data->appends(['name' => $namePage])->links() }} //simplePaginate() 方法分页视图中简单的显示“下一页”和“上一页”链接
$data = DB::table('users')->simplePaginate(2);
//返回给前端视图数据
return $this->view('index',['data'=>$data]);
//前端简单引用代码
<div class="container">
@foreach ($users as $user)
{{ $user->name }}
@endforeach
</div>
{{ $data->links() }} //原生分页写法
$page = 2;
$pageSize = 1;
$offset = ($page - 1) * $pageSize;
$result = DB::table('picasa')
->where('title', 'like', '%'.$title.'%')
->offset($offset)
->limit($pageSize)
->get(); //返回数据视图文件
return $this->view('index', ['result' => $result]); }
}

groupBy  对查询结果进行分组出现问题

 当select和groupBy中列表不一致时候会报错。mysql从5.7以后,默认开启group by的严格模式。

 解决方法:找到config/database​.php 在mysql下面把'strict' => true,改为false。[建议不要修改。写对正确操作语法。]

 例如:
$booked = DB::table('booked_user')
->select('game_id', DB::raw('count(*) as total'))
->groupBy('game_id')
->get();

开启sql查询日志

  DB::connection()->enableQueryLog();//开启QueryLog
$data = DB::table('users')->select('id','name', 'email')->get();//执行sql
dump(DB::getQueryLog());//sql语句和查询时间

写入日志信息

八种日志级别:emergency、alert、critical、error、warning、 notice、info 和 debug
默认日志存放位置: /storage/logs/laravel.log
引用: use Illuminate\Support\Facades\Log;

 Log::emergency(string $message, array $context = []);
Log::alert(string $message, array $context = []);
Log::critical(string $message, array $context = []);
Log::error(string $message, array $context = []);
Log::warning(string $message, array $context = []);
Log::notice(string $message, array $context = []);
Log::info(string $message, array $context = []);
Log::debug(string $message, array $context = []);

 laravel5.6 操作数据ORM链接:  请点击跳转

laravel5.6操作数据curd写法(查询构建器)的更多相关文章

  1. Laravel5.1 数据库-查询构建器

    今儿个咱说说查询构建器.它比运行原生SQL要简单些,它的操作面儿也是比较广泛的. 1 查询结果 先来看看它的语法: public function getSelect() { $result = DB ...

  2. DB门面,查询构建器,Eloquent ORM三者的CURD

    一.DB门面 1.insert DB::insert('insert into table(`name`) value(?)', ['test']); 2.update DB::update('upd ...

  3. [转]Laravel 数据库实例教程 —— 使用查询构建器实现对数据库的高级查询

    本文转自:https://laravelacademy.org/post/920.html 上一节我们简单介绍了如何使用查询构建器对数据库进行基本的增删改查操作,这一节我们来探讨如何使用查询构建器实现 ...

  4. Yii2 查询构建器 QueryBuilder

    查询构造器 QueryBuilder 1.什么是查询构建器 查询构建器也是建立在 DAO 基础之上,可让你创建程序化的.DBMS 无关的 sql 语句,并且这样创建的 sql 语句比原生的 sql 语 ...

  5. Laravel 数据库实例教程 —— 使用查询构建器对数据库进行增删改查

    原文地址:https://blog.csdn.net/lmy_love_/article/details/72832259 获取查询构建器很简单,还是要依赖DB门面,我们使用DB门面的table方法, ...

  6. laravel 查询构建器(连贯操作)

    注:laravel 查询返回行的都是 php 的 stdClass 对象实例,不是数组!!!! 1)查询多行(get) DB::table('table_name')->get(); 带偏移和限 ...

  7. 定义查询构建器IFeatureLayerDefinition

    在宗地出图,需要实现,只显示某一户人的地块.在ArcMap里,有个定义查询,可只显示过滤后的要素. 在代码中,也比较好实现,使用IFeatureLayerDefinition接口即可. IFeatur ...

  8. yii2 查询构建器

    Query Builder $rows = (new \yii\db\Query()) ->select(['dyn_id', 'dyn_name']) ->from('zs_dynast ...

  9. Yii2将查询数据变为键值对数组及查询构建器

随机推荐

  1. Spring Boot 之 springcache的使用

    一.开启 springcache,启动类添加 @EnableCaching 注解 @SpringBootApplication @EnableCaching public class Gatherin ...

  2. EL表达式.jsp指令等

    1.JSP标准指令:<%@ 标准指令(属性 )%><%@ page %><%@ include %><%@ taglib %> 2.JSP程序代码元素: ...

  3. es6 export及export default 的使用 及 区别

    首先要知道export,import ,export default是什么 ES6模块主要有两个功能:export和importexport用于对外输出本模块(一个文件可以理解为一个模块)变量的接口i ...

  4. SpringBoot 使用logback

    1.添加pom引用 <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback ...

  5. sql Server20008总结

    1.like------->常用于“数据库的模糊查询” 1)即:查询某个字段中含有哪些的内容的数据库的信息列表(详情) 比如:查询学生表中名字姓是‘韩’的所有学生的信息 select * fro ...

  6. python之设置windows背景图片

    #!/usr/bin/env python3 # -*- coding: utf-8 -*- __author__ = 'jiangwenwen' from PIL import Image impo ...

  7. python学习第四十六天dir( )函数用法

    dir( )函数有点像目录的意思,但是他是包含由模块定义的名称的字符串的排序列表.这个列表包含模块中定义的所有模块,变量和函数的名称. 列举其用法 import time content = dir( ...

  8. 修改url,

    第一种场景: 无论url怎么变,表单里面的url始终不变 http://127.0.0.1:8000/CC/indexssssssssssssssssss/ url(r'^indexsssssssss ...

  9. asp.net Swiper 轮播动画

    原文:https://blog.csdn.net/qq_39656138/article/details/90451289 官网:https://www.swiper.com.cn/api/index ...

  10. 10java进阶——IO2

    1. Properties类 Properties 类表示了一个持久的属性集.Properties 可保存在流中或从流中加载.属性列表中每个键及其对应值都是一个字符串. 特点: Hashtable的子 ...