您现在的位置是:网站首页> 编程资料编程资料

laravel5.6框架操作数据curd写法(查询构建器)实例分析_php实例_

2023-05-25 333人已围观

简介 laravel5.6框架操作数据curd写法(查询构建器)实例分析_php实例_

本文实例讲述了laravel5.6框架操作数据curd写法(查询构建器)。分享给大家供大家参考,具体如下:

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

 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]); //前端简单引用代码 
@foreach ($users as $user) {{ $user->name }} @endforeach
{{ $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

更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。

-六神源码网