• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    laravel5.6框架操作数据curd写法(查询构建器)实例分析

    本文实例讲述了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

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

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

    您可能感兴趣的文章:
    • Laravel5.1 框架数据库查询构建器用法实例详解
    • laravel框架数据库操作、查询构建器、Eloquent ORM操作实例分析
    • laravel通用化的CURD的实现
    • Laravel框架查询构造器 CURD操作示例
    • Laravel框架实现model层的增删改查(CURD)操作示例
    • Laravel框架数据库CURD操作、连贯操作总结
    • laravel5.6 框架操作数据 Eloquent ORM用法示例
    • laravel 操作数据库常用函数的返回值方法
    • laravel框架数据库配置及操作数据库示例
    上一篇:laravel5.6 框架操作数据 Eloquent ORM用法示例
    下一篇:laravel5.6 框架邮件队列database驱动简单demo示例
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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