首页 > 作文

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

更新时间:2023-04-08 14:49:42 阅读: 评论:0

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

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

<?php//laravel5.6 语法 demo示例namespace app\http\controllers;//命名该控制app空间下名称u illuminate\support\facades\db;//使用db操作数据库u app\http\controllers\controller;//继承基础控制器class urcontroller extends controller{ /**  * 展示应用的用户列表.  *  * @return respon  */ public function index() {  //db使用为每种操作提供了相应方法:lect(查),update(修改),inrt(插入),delete(删除),statement(声明)  //建议占位符,其他框架通用性强  //原生sql写法  $data = db::lect('lect * from urs where id = :id and name = :name ',[':id' => 1,':name' =>'测试']);  //查方法  //get() 方法获取表中所有记录(获取多行多列)  $data = db::table('urs')->get();  //first() 方法将会返回单个对象(获取一行一列)  //where(端午节红包发多少合适) 方法查询指定条件对象  $data = db::table('urs')->where('id','name','3','测试')->first();  //lect() 方法可以查询指定自定义字段  $data = db::table('urs')->lect('id','name', 'email')->get();  //value() 方法从结果中获取单个值,该方法会直接返回指定列的值:  $data = db::table('urs')->where('name','测试')->value('email');  //pluck() 方法获取单个列值的数组  $data = db::table('urs')->pluck('name');  //count() 统计数量  $data = db::table('urs')->count();  //exists() 方法来判断匹配查询条件的结果是否存在  $data=db::table('urs')->where('id', 1)->exists();  //join() 方法连表查询  $data = db::table('urs')   ->join('ceshi', 'urs.id', '=', 'ceshi.id')   ->lect('urs.*', 'ceshi.name')   ->get();  //leftjoin() 方法左连表查询  $data = db::table('urs')   ->leftjoin('ceshi', 'urs.id', '=', 'ceshi.id')   ->lect('urs.*', 'ceshi.name')   ->get();  //where() 参数说明:(一)参数是列名,(二)参数是操作符,(三)参数是该列要比较的值  $data = db::table('urs')   ->where('id', '>=', 1)   ->where('name', 'like', '测试%')   ->get();  //传递条件数组到where中写法,建议多where查询使用这个方法  $data光辉女郎加点 = db::table('urs')   ->where([    ['id', '>=', 1],    ['name', 'like', '测试%']   ])   ->get();  //wherebetween() 方法验证列值是否在给定值之间  $data = db::table('urs')   ->wherebetween('id', [1, 3])->get();  //wherein 方法验证给定列的值是否在给定数组中:  $data = db::table('urs')   ->wherein('id', [1, 2, 3])   ->get();  //orderby() 方法排序  $data = db::table('urs')   ->orderby('id', 'desc')   ->get();  //inrt()  方法2022北京冬奥会插入记录到数据表  //inrtgetid() 方法插入记录并返回自增id值  $data=db::table('urs')->inrt(   [    'name'=>'测试',    'email' => 'ceshi.com',    'password' => 'ceshi'   ]  );  //update() 方法修改记录  $data =db::table('urs')   ->where('id', 1)   ->update(['name' => '测试']);  //delete() 方法删除记录  $data=db::table('urs')->where('id', '>', 10)->delete();  //paginate() 方法分页 每页显示数量  //注意:目前使用 公务员几号发工资groupby 的分页操作不能被laravel有效执行  $data = db::table('urs')->paginate(2);  //前台分页中链接附加参数实现分页  $getname = $get['name']?:'';  $data = db::table('urs')    ->lect('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('urs')->simplepaginate(2);  //返回给前端视图数据  return $this->view('index',['data'=>$data]);  //前端简单引用代码   <div class="container">  @foreach ($urs as $ur)   {{ $ur->name }}  @endforeach  </div>  {{ $data->links() }}  //原生分页写法  $page = 2;  $pagesize = 1;  $offt = ($page - 1) * $pagesize;  $result = db::table('picasa')   ->where('title', 'like', '%'.$title.'%')   ->offt($offt)   ->limit($pagesize)   ->get();  //返回数据视图文件  return $this->view('index', ['result' => $result]); }}

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

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

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

例如:

$booked = db::table('booked_ur') ->lect('game_id', db::raw('count(*) as total')) ->groupby('game_id') ->get();

开启sql查询日志

db::connection()->enablequerylog();//开启querylog$data = db::table('urs')->lect('id','name', 'email')->get();//执行sqldump(db::getqueryl1亩等于多少平方og());//sql语句和查询时间

写入日志信息

八种日志级别:emergency、alert、critical、error、warning、 notice、info 和 debug
默认日志存放位置: /storage/logs/laravel.log

引用: u 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

本文发布于:2023-04-08 14:49:41,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/686f499d39a5ac42a60e0efb19dbf95b.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:laravel5.6框架操作数据curd写法(查询构建器)实例分析.doc

本文 PDF 下载地址:laravel5.6框架操作数据curd写法(查询构建器)实例分析.pdf

标签:方法   分页   操作   测试
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图