laravel5.6框架操作数据curd写法(查询构建器)实例分析
本文实例讲述了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($usersas$user)
{{$user->name}}
@endforeach
groupBy 对查询结果进行分组出现问题
当select和groupBy中列表不一致时候会报错。mysql从5.7以后,默认开启groupby的严格模式。
解决方法:找到config/database.php在mysql下面把'strict'=>true,改为false。[建议不要修改。写对正确操作语法。]
例如:
$booked=DB::table('booked_user')
->select('game_id',DB::raw('count(*)astotal'))
->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
引用:useIlluminate\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程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。