系统城装机大师 - 固镇县祥瑞电脑科技销售部宣传站!

当前位置:首页 > 网络编程 > PHP编程 > 详细页面

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

时间:2020-02-03来源:系统城作者:电脑系统城

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

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


 
  1. <?php
  2. //laravel5.6 语法 demo示例
  3. namespace App\Http\Controllers;//命名该控制App空间下名称
  4. use Illuminate\Support\Facades\DB;//使用DB操作数据库
  5. use App\Http\Controllers\Controller;//继承基础控制器
  6. class UserController extends Controller
  7. {
  8. /**
  9. * 展示应用的用户列表.
  10. *
  11. * @return Response
  12. */
  13. public function index()
  14. {
  15. //DB使用为每种操作提供了相应方法:select(查),update(修改),insert(插入),delete(删除),statement(声明)
  16. //建议占位符,其他框架通用性强
  17. //原生sql写法
  18. $data = DB::select('select * from users where id = :id and name = :name ',[':id' =>1,':name' =>'测试']);
  19. //查方法
  20. //get() 方法获取表中所有记录(获取多行多列)
  21. $data = DB::table('users')->get();
  22. //first() 方法将会返回单个对象(获取一行一列)
  23. //where() 方法查询指定条件对象
  24. $data = DB::table('users')->where('id','name','3','测试')->first();
  25. //select() 方法可以查询指定自定义字段
  26. $data = DB::table('users')->select('id','name', 'email')->get();
  27. //value() 方法从结果中获取单个值,该方法会直接返回指定列的值:
  28. $data = DB::table('users')->where('name','测试')->value('email');
  29. //pluck() 方法获取单个列值的数组
  30. $data = DB::table('users')->pluck('name');
  31. //count() 统计数量
  32. $data = DB::table('users')->count();
  33. //exists() 方法来判断匹配查询条件的结果是否存在
  34. $data=DB::table('users')->where('id', 1)->exists();
  35. //join() 方法连表查询
  36. $data = DB::table('users')
  37. ->join('ceshi', 'users.id', '=', 'ceshi.id')
  38. ->select('users.*', 'ceshi.name')
  39. ->get();
  40. //leftJoin() 方法左连表查询
  41. $data = DB::table('users')
  42. ->leftJoin('ceshi', 'users.id', '=', 'ceshi.id')
  43. ->select('users.*', 'ceshi.name')
  44. ->get();
  45. //where() 参数说明:(一)参数是列名,(二)参数是操作符,(三)参数是该列要比较的值
  46. $data = DB::table('users')
  47. ->where('id', '>=', 1)
  48. ->where('name', 'like', '测试%')
  49. ->get();
  50. //传递条件数组到where中写法,建议多where查询使用这个方法
  51. $data = DB::table('users')
  52. ->where([
  53. ['id', '>=', 1],
  54. ['name', 'like', '测试%']
  55. ])
  56. ->get();
  57. //whereBetween() 方法验证列值是否在给定值之间
  58. $data = DB::table('users')
  59. ->whereBetween('id', [1, 3])->get();
  60. //whereIn 方法验证给定列的值是否在给定数组中:
  61. $data = DB::table('users')
  62. ->whereIn('id', [1, 2, 3])
  63. ->get();
  64. //orderBy() 方法排序
  65. $data = DB::table('users')
  66. ->orderBy('id', 'desc')
  67. ->get();
  68. //insert() 方法插入记录到数据表
  69. //insertGetId() 方法插入记录并返回自增ID值
  70. $data=DB::table('users')->insert(
  71. [
  72. 'name'=>'测试',
  73. 'email' => 'ceshi.com',
  74. 'password' => 'ceshi'
  75. ]
  76. );
  77. //update() 方法修改记录
  78. $data =DB::table('users')
  79. ->where('id', 1)
  80. ->update(['name' => '测试']);
  81. //delete() 方法删除记录
  82. $data=DB::table('users')->where('id', '>', 10)->delete();
  83. //paginate() 方法分页 每页显示数量
  84. //注意:目前使用 groupBy 的分页操作不能被Laravel有效执行
  85. $data = DB::table('users')->paginate(2);
  86. //前台分页中链接附加参数实现分页
  87. $getName = $GET['name']?:'';
  88. $data = DB::table('users')
  89. ->select('id','name','age')
  90. ->where('name', 'like', $getName.'%')
  91. ->paginate(2);
  92. //返回给前端视图数据
  93. return $this->view('index',['data'=>$data,'namePage'=>$getName]);
  94. //前端引用代码
  95. //appends 方法添加查询参数到分页链接查询字符串; 添加 &name=$namePage到每个分页链接中.
  96. {{ $data->appends(['name' => $namePage])->links() }}
  97. //simplePaginate() 方法分页视图中简单的显示“下一页”和“上一页”链接
  98. $data = DB::table('users')->simplePaginate(2);
  99. //返回给前端视图数据
  100. return $this->view('index',['data'=>$data]);
  101. //前端简单引用代码
  102. <div class="container">
  103. @foreach ($users as $user)
  104. {{ $user->name }}
  105. @endforeach
  106. </div>
  107. {{ $data->links() }}
  108. //原生分页写法
  109. $page = 2;
  110. $pageSize = 1;
  111. $offset = ($page - 1) * $pageSize;
  112. $result = DB::table('picasa')
  113. ->where('title', 'like', '%'.$title.'%')
  114. ->offset($offset)
  115. ->limit($pageSize)
  116. ->get();
  117. //返回数据视图文件
  118. return $this->view('index', ['result' => $result]);
  119. }
  120. }
  121.  

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

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

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

例如:


 
  1. $booked = DB::table('booked_user')
  2. ->select('game_id', DB::raw('count(*) as total'))
  3. ->groupBy('game_id')
  4. ->get();
  5.  

开启sql查询日志


 
  1. DB::connection()->enableQueryLog();//开启QueryLog
  2. $data = DB::table('users')->select('id','name', 'email')->get();//执行sql
  3. dump(DB::getQueryLog());//sql语句和查询时间
  4.  

写入日志信息

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

引用: use Illuminate\Support\Facades\Log;


 
  1. Log::emergency(string $message, array $context = []);
  2. Log::alert(string $message, array $context = []);
  3. Log::critical(string $message, array $context = []);
  4. Log::error(string $message, array $context = []);
  5. Log::warning(string $message, array $context = []);
  6. Log::notice(string $message, array $context = []);
  7. Log::info(string $message, array $context = []);
  8. Log::debug(string $message, array $context = []);
  9.  

laravel5.6 操作数据ORM

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

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

分享到:

相关信息

  • Thinkphp框架+Layui实现图片/文件上传功能分析

    这篇文章主要介绍了Thinkphp框架+Layui实现图片/文件上传功能,结合实例形式详细分析了Thinkphp+Layui实现图片文件上传的具体步骤、原理与相关操作技巧...

    2020-02-07

  • Laravel框架自定义分页样式操作示例

    这篇文章主要介绍了Laravel框架自定义分页样式操作,结合实例形式详细分析了laravel框架自定义分页样式的具体操作步骤、实现方法及相关注意事项,需要的朋友可以参考下...

    2020-02-03

系统教程栏目

栏目热门教程

人气教程排行

站长推荐

热门系统下载