laravel5.6操作数据curd写法(查询构建器)
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写法(查询构建器)的更多相关文章
- Laravel5.1 数据库-查询构建器
今儿个咱说说查询构建器.它比运行原生SQL要简单些,它的操作面儿也是比较广泛的. 1 查询结果 先来看看它的语法: public function getSelect() { $result = DB ...
- DB门面,查询构建器,Eloquent ORM三者的CURD
一.DB门面 1.insert DB::insert('insert into table(`name`) value(?)', ['test']); 2.update DB::update('upd ...
- [转]Laravel 数据库实例教程 —— 使用查询构建器实现对数据库的高级查询
本文转自:https://laravelacademy.org/post/920.html 上一节我们简单介绍了如何使用查询构建器对数据库进行基本的增删改查操作,这一节我们来探讨如何使用查询构建器实现 ...
- Yii2 查询构建器 QueryBuilder
查询构造器 QueryBuilder 1.什么是查询构建器 查询构建器也是建立在 DAO 基础之上,可让你创建程序化的.DBMS 无关的 sql 语句,并且这样创建的 sql 语句比原生的 sql 语 ...
- Laravel 数据库实例教程 —— 使用查询构建器对数据库进行增删改查
原文地址:https://blog.csdn.net/lmy_love_/article/details/72832259 获取查询构建器很简单,还是要依赖DB门面,我们使用DB门面的table方法, ...
- laravel 查询构建器(连贯操作)
注:laravel 查询返回行的都是 php 的 stdClass 对象实例,不是数组!!!! 1)查询多行(get) DB::table('table_name')->get(); 带偏移和限 ...
- 定义查询构建器IFeatureLayerDefinition
在宗地出图,需要实现,只显示某一户人的地块.在ArcMap里,有个定义查询,可只显示过滤后的要素. 在代码中,也比较好实现,使用IFeatureLayerDefinition接口即可. IFeatur ...
- yii2 查询构建器
Query Builder $rows = (new \yii\db\Query()) ->select(['dyn_id', 'dyn_name']) ->from('zs_dynast ...
- Yii2将查询数据变为键值对数组及查询构建器
随机推荐
- Jenkins持续集成_03_添加测试报告
前言 Jenkins持续集成自动化测试项目后,可以在控制台输出中查看测试结果,但是这样排查起来往往不够直观.为了更直观的查看测试结果,可以在Jenkins上展示测试报告.测试报告中测试结果情况展示的更 ...
- 应用安全-软件安全-漏洞CVE整理
jira ssrf CVE-2019-8451 url = url + '/plugins/servlet/gadgets/makeRequest?url=' + host + '@www.baidu ...
- Hyperledger:Fabric CA 用户指南 [译]
Fabric CA 用户指南 Fabric CA 是 Hyperledger Fabric 的官方配套认证设施. 原文链接:http://hyperledger-fabric.readthedocs. ...
- Linux 文件创建、插入、替换
创建文件 touch newfile.txt 插入字符串 echo "aaa" >>/newfile.txt 替换字符串 sed -i "s/aaa/ccc/ ...
- Myeclipse 快捷键大全(绝对全)
非常感谢分享这篇文章的大虾..但是我忘了几下您的blog地址,因此无法注明原文地址...见谅哈 存盘 Ctrl+s(肯定知道) 注释代码 Ctrl+/ 取消注释 Ctrl+\(Eclipse3已经都合 ...
- Vue 基础 day02
Vue Devtools 安装 https://chrome.google.com/webstore/search/vue%20devtools?hl=zh-CN 需要翻墙 过滤器 概念: Vue.j ...
- SpringBoot(六) -- SpringBoot错误处理机制
一.SpringBoot中的默认的错误处理机制 1.在SpringBootWeb开发中,当我们访问请求出现错误时,会返回一个默认的错误页面: 2.在使用其他客户端访问的时候,则返回一个json数据: ...
- C#中Func与Action的理解
Action 与 Func是.NET类库中增加的内置委托,以便更加简洁方便的使用委托.最初使用委托时,均需要先定义委托类型,然后定义一个符合委托类型签名的函数,在调用前,需声明并创建委托对象,将指定函 ...
- Spring-Boot 整合Dubbo 解决@Reference 注解为null情况
首先检查一下你的spring boot版本是多少? 如果是2.X 不用看了,spring boot 2.x 必定会出现这个问题, 改为 1.5.9 或其他1.x版本,目前生产环境建议使用1.x版本. ...
- BZOJ4753: [Jsoi2016]最佳团体(分数规划+树上背包)
BZOJ4753: [Jsoi2016]最佳团体(分数规划+树上背包) 标签:题解 阅读体验 BZOJ题目链接 洛谷题目链接 具体实现 看到分数和最值,考虑分数规划 我们要求的是一个\(\dfrac{ ...