Blogger Information
Blog 34
fans 0
comment 0
visits 22521
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
12月31日—laravel框架的使用查询构造器对数据库进行增删查改操作
曾龙宇
Original
648 people have browsed it

路由文件

  1. //用户添加路由
  2. Route::get('/user/add','UserController@add');
  3. Route::post('/user/store','UserController@store');
  4. Route::get('/user/index','UserController@index');
  5. Route::get('/user/edit/{id}','UserController@edit');
  6. Route::post('/user/save','UserController@save');
  7. Route::get('/user/delete/{id}','UserController@delete');

Controller文件

  1. <?php
  2. namespace App\Http\Controllers;
  3. use Illuminate\Http\Request;
  4. use Illuminate\Support\Facades\DB;
  5. class UserController extends Controller
  6. {
  7. public function index(){
  8. // $data = DB::table('person')->orderBy('id','desc')->get();
  9. $data = DB::table('person')->select('id','name','age','email','phone')->get();
  10. return view('person.list',['data'=>$data]);
  11. }
  12. public function add(){
  13. return view('person.add');
  14. }
  15. public function store(Request $request){
  16. $name = $request->input('name');
  17. $age = $request->input('age');
  18. $email = $request->input('email');
  19. $phone = $request->input('phone');
  20. $res = DB::table('person')->insert(['name'=>$name,'age'=>$age,'email'=>$email,'phone'=>$phone]);
  21. if ($res){
  22. echo json_encode(array('code'=>1,'msg'=>'添加成功'));
  23. }else{
  24. echo json_encode(array('code'=>0,'msg'=>'添加失败'));
  25. }
  26. }
  27. public function edit($id){
  28. $data = DB::table('person')->where('id',$id)->get();
  29. return view('person.edit',['data'=>$data]);
  30. }
  31. public function save(Request $request){
  32. $id = $request->input('id');
  33. $name = $request->input('name');
  34. $age = $request->input('age');
  35. $email = $request->input('email');
  36. $phone = $request->input('phone');
  37. $res = DB::table('person')->where('id',$id)->update(['name'=>$name,'age'=>$age,'email'=>$email,'phone'=>$phone]);
  38. if ($res){
  39. echo json_encode(array('code'=>1,'msg'=>'编辑成功'));
  40. }else{
  41. echo json_encode(array('code'=>0,'msg'=>'编辑失败'));
  42. }
  43. }
  44. public function delete($id){
  45. $res = DB::table('person')->where('id',$id)->delete();
  46. if ($res){
  47. echo '<script>alert("删除成功");window.location.href="/user/index";</script>';
  48. }else{
  49. echo '<script>alert("删除失败");window.reload();</script>';
  50. }
  51. }
  52. }

list界面

  1. <!doctype html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport"
  6. content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>展示界面</title>
  9. <style>
  10. a{text-decoration: none;}
  11. </style>
  12. </head>
  13. <body>
  14. <button><a href="/user/add">添加</a></button>
  15. <table border="1" cellpadding="4" style="border-collapse: collapse;">
  16. <caption>展示界面</caption>
  17. <tr>
  18. <th>ID</th>
  19. <th>姓名</th>
  20. <th>年龄</th>
  21. <th>邮箱</th>
  22. <th>电话</th>
  23. <th>操作</th>
  24. </tr>
  25. @foreach($data as $item)
  26. <tr>
  27. <td>{{$item->id}}</td>
  28. <td>{{$item->name}}</td>
  29. <td>{{$item->age}}</td>
  30. <td>{{$item->email}}</td>
  31. <td>{{$item->phone}}</td>
  32. <td><button><a href='/user/edit/{{$item->id}}'>编辑</a></button>
  33. <button><a href='/user/delete/{{$item->id}}' onclick="if(confirm('是否删除数据?')==false)return false;">删除</a></button>
  34. </td>
  35. </tr>
  36. @endforeach
  37. </table>
  38. <script>
  39. </script>
  40. </body>
  41. </html>

add界面

  1. <!doctype html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport"
  6. content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>添加界面</title>
  9. <script src="{{asset('js/jquery.min.js')}}"></script>
  10. </head>
  11. <body>
  12. <form action="" name="add_form">
  13. <table border="1" cellpadding="4" style="border-collapse:collapse;">
  14. <input type="hidden" name="_token" value="{{csrf_token()}}">
  15. <caption>添加用户信息</caption>
  16. <tr>
  17. <td>姓名</td>
  18. <td><input type="text" name="name" placeholder="请输入姓名"></td>
  19. </tr>
  20. <tr>
  21. <td>年龄</td>
  22. <td><input type="text" name="age" placeholder="请输入年龄"></td>
  23. </tr>
  24. <tr>
  25. <td>邮箱</td>
  26. <td><input type="text" name="email" placeholder="请输入邮箱"></td>
  27. </tr>
  28. <tr>
  29. <td>电话</td>
  30. <td><input type="text" name="phone" placeholder="请输入电话"></td>
  31. </tr>
  32. <tr>
  33. <td colspan="2"><button type="button" onclick="doSave()">保存</button></td>
  34. </tr>
  35. </table>
  36. </form>
  37. <script>
  38. function doSave() {
  39. var name = $.trim($('input[name="name"]').val());
  40. var age = $.trim($('input[name="age"]').val());
  41. var email = $.trim($('input[name="email"]').val());
  42. var phone = $.trim($('input[name="phone"]').val());
  43. if (name==''){
  44. alert('请输入姓名');
  45. return;
  46. }
  47. if (age==''){
  48. alert('请输入年龄');
  49. return;
  50. }
  51. if (email==''){
  52. alert('请输入邮箱');
  53. return;
  54. }
  55. if (phone==''){
  56. alert('请输入电话');
  57. return;
  58. }
  59. $.post('/user/store',$('form[name="add_form"]').serialize(),function (res) {
  60. if(res.code==0){
  61. alert(res.msg);
  62. return;
  63. }else{
  64. alert(res.msg);
  65. window.location.href = '/user/index';
  66. }
  67. },'json');
  68. }
  69. </script>
  70. </body>
  71. </html>

edit界面

  1. <!doctype html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport"
  6. content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>编辑界面</title>
  9. <script src="{{asset('js/jquery.min.js')}}"></script>
  10. </head>
  11. <body>
  12. <form action="" name="add_form">
  13. <table border="1" cellpadding="4" style="border-collapse:collapse;">
  14. <input type="hidden" name="_token" value="{{csrf_token()}}">
  15. @foreach ($data as $item)
  16. <input type="hidden" name="id" value="{{$item->id}}">
  17. <caption>编辑用户信息</caption>
  18. <tr>
  19. <td>姓名</td>
  20. <td><input type="text" name="name" value="{{$item->name}}"></td>
  21. </tr>
  22. <tr>
  23. <td>年龄</td>
  24. <td><input type="text" name="age" value="{{$item->age}}"></td>
  25. </tr>
  26. <tr>
  27. <td>邮箱</td>
  28. <td><input type="text" name="email" value="{{$item->email}}"></td>
  29. </tr>
  30. <tr>
  31. <td>电话</td>
  32. <td><input type="text" name="phone" value="{{$item->phone}}"></td>
  33. </tr>
  34. <tr>
  35. <td colspan="2"><button type="button" onclick="doSave()">保存</button></td>
  36. </tr>
  37. @endforeach
  38. </table>
  39. </form>
  40. <script>
  41. function doSave() {
  42. var name = $.trim($('input[name="name"]').val());
  43. var age = $.trim($('input[name="age"]').val());
  44. var email = $.trim($('input[name="email"]').val());
  45. var phone = $.trim($('input[name="phone"]').val());
  46. if (name==''){
  47. alert('请输入姓名');
  48. return;
  49. }
  50. if (age==''){
  51. alert('请输入年龄');
  52. return;
  53. }
  54. if (email==''){
  55. alert('请输入邮箱');
  56. return;
  57. }
  58. if (phone==''){
  59. alert('请输入电话');
  60. return;
  61. }
  62. $.post('/user/save',$('form[name="add_form"]').serialize(),function (res) {
  63. if(res.code==0){
  64. alert(res.msg);
  65. return;
  66. }else{
  67. alert(res.msg);
  68. window.location.href = '/user/index';
  69. }
  70. },'json');
  71. }
  72. </script>
  73. </body>
  74. </html>

where方法

传递三个参数,第一个参数是列名,第二个参数是任意一个数据库系统支持的运算符,第三个是该列要比较的值。例如:where(‘id’,’=’,’1’)

  1. $data = DB::table('person')->where('id','=','3')->get();

whereIn方法

验证字段的值必须存在指定的数组里,两个参数,第一个参数是列名,第二个参数是数组,例如:whereIn(‘id’,[1,3,5])

  1. $data = Db::table('person')->whereIn('id',[1,3,4])->get();

insert方法,返回是否插入成功,布尔值

插入记录到数据库中,接收数组形式的字段名和字段值进行插入操作。insert中可以接收一个数组,也可以接收多个数组
例如:insert([‘name’=>’张三’,’age’=>’24’])
insert([‘name’=>’张三’,’age’=>’24’],[‘name’=>’李四’,’age’=>’45’],[‘name’=>’王五’,’age’=>’68’])

  1. $res = DB::table('person')->insert(['name'=>'小明','age'=>'26','email'=>'qwe@qq.com','phone'=>'10086']);
  2. $res = DB::table('person')->insert(
  3. ['name'=>'小明','age'=>'26','email'=>'qwe@qq.com','phone'=>'10086'],['name'=>'小军','age'=>'32','email'=>'jun@qq.com','phone'=>'10086'],['name'=>'小红','age'=>'45','email'=>'hon@qq.com','phone'=>'10086']);

insertGetId,插入记录并返回id值

  1. $res = DB::table('person')->insertGetId(['name'=>'小明','age'=>'26','email'=>'qwe@qq.com','phone'=>'10086']);

update更新方法

通过where增加更新条件,update里面用数组形式传值

  1. $res = DB::table('person')->where('id',$id)->update(['name'=>$name,'age'=>$age,'email'=>$email,'phone'=>$phone]);

increment自增

第一个参数:需要修改的列。第二个参数是可选的,用于控制列递增的量
通常用在计算登录次数,点赞数等
$res = Db::table(‘person’)->increment(‘login_num’);

delete删除方法

  1. $res = DB::table('person')->where('id',$id)->delete();

truncate清空表方法

删除所有行,并重置自增 ID 为零

  1. $res = DB::table('person')->truncate()
Correcting teacher:天蓬老师天蓬老师

Correction status:qualified

Teacher's comments:laravel 的数据库操作有三种方式, 在开发过程中, 根据情况, 任选 一个都可以的
Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post