BookAdjustOne.php 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. namespace App\Console\Commands;
  3. use Illuminate\Console\Command;
  4. use DB;
  5. class BookAdjustOne extends Command
  6. {
  7. /**
  8. * The name and signature of the console command.
  9. *
  10. * @var string
  11. */
  12. protected $signature = 'book:adjustone {--bid= : the id of a book}';
  13. /**
  14. * The console command description.
  15. *
  16. * @var string
  17. */
  18. protected $description = '调整所有章节顺序prev_cid和next_cid';
  19. /**
  20. * Create a new command instance.
  21. *
  22. * @return void
  23. */
  24. public function __construct()
  25. {
  26. parent::__construct();
  27. }
  28. /**
  29. * Execute the console command.
  30. *
  31. * @return mixed
  32. */
  33. public function handle()
  34. {
  35. $bid = $this->option('bid');
  36. if(empty($bid)) return 0;
  37. $this->adjustSequentOne($bid);
  38. }
  39. /**
  40. * 调整单本书的顺序
  41. * @param $bid
  42. */
  43. public function adjustSequentOne($bid){
  44. $chapter_list = DB::table('chapters')->orderBy('sequence')->where('bid',$bid)->select('id')->get();
  45. $prev = 0;
  46. foreach ($chapter_list as $chapter){
  47. if($prev){
  48. DB::table('chapters')->where('id',$chapter->id)->update(['prev_cid'=>$prev]);
  49. DB::table('chapters')->where('id',$prev)->update(['next_cid'=>$chapter->id]);
  50. }
  51. $prev = $chapter->id;
  52. }
  53. }
  54. }