laravel5.6框架操作数据curd写法(查询构建器)实例分析
发布:smiling 来源: PHP粉丝网 添加日期:2022-02-08 09:07:22 浏览: 评论:0
本文实例讲述了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 = []);
 
Tags: laravel5.6查询构建器 curd
相关文章
- ·Laravel 5.6中的CURD操作(代码示例详解)(2020-01-15)
 - ·Laravel框架数据库CURD操作、连贯操作总结(2021-04-10)
 - ·yii的CURD操作实例详解(2021-05-02)
 - ·Yii框架实现对数据库的CURD操作示例(2021-12-14)
 - ·Laravel框架查询构造器 CURD操作示例(2021-12-15)
 - ·laravel通用化的CURD的实现(2022-01-28)
 
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
 - PHP新手上路(一)(7)
 - 惹恼程序员的十件事(5)
 - PHP邮件发送例子,已测试成功(5)
 - 致初学者:PHP比ASP优秀的七个理由(4)
 - PHP会被淘汰吗?(4)
 - PHP新手上路(四)(4)
 - 如何去学习PHP?(2)
 - 简单入门级php分页代码(2)
 - php中邮箱email 电话等格式的验证(2)
 
