WordIndexController.php 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\WordIndex;
  4. use Illuminate\Http\Request;
  5. use App\Http\Resources\WordIndexResource;
  6. use Illuminate\Support\Facades\Cache;
  7. use App\Tools\RedisClusters;
  8. use Illuminate\Support\Facades\Log;
  9. use Illuminate\Support\Facades\DB;
  10. class WordIndexController extends Controller
  11. {
  12. /**
  13. * Display a listing of the resource.
  14. *
  15. * @return \Illuminate\Http\Response
  16. */
  17. public function index(Request $request)
  18. {
  19. //
  20. switch ($request->get("view")) {
  21. case 'key':
  22. $key = $request->get("key");
  23. /*
  24. $result = RedisClusters::remember("/word_index/{$key}",10,function() use($key){
  25. return WordIndex::where('word','like',$key."%")
  26. ->whereOr('word_en','like',$key."%")
  27. ->orderBy('word_en')
  28. ->take(10)->get();
  29. });
  30. $table = WordIndex::where('word','like',$key."%")
  31. ->whereOr('word_en','like',$key."%")
  32. ->orderBy('len')
  33. ->orderBy('word_en')
  34. ->take(10);
  35. Log::info($table->toSql());
  36. $result = $table->get();
  37. */
  38. $result = DB::select("SELECT * from word_indices where word like ? or word_en like ? order by len, word_en limit 10",[$key."%",$key."%"]);
  39. return $this->ok(['rows'=>$result,'count'=>count($result)]);
  40. break;
  41. default:
  42. return $this->error('view error');
  43. break;
  44. }
  45. }
  46. /**
  47. * Store a newly created resource in storage.
  48. *
  49. * @param \Illuminate\Http\Request $request
  50. * @return \Illuminate\Http\Response
  51. */
  52. public function store(Request $request)
  53. {
  54. //
  55. }
  56. /**
  57. * Display the specified resource.
  58. *
  59. * @param \App\Models\WordIndex $wordIndex
  60. * @return \Illuminate\Http\Response
  61. */
  62. public function show(WordIndex $wordIndex)
  63. {
  64. //
  65. }
  66. /**
  67. * Update the specified resource in storage.
  68. *
  69. * @param \Illuminate\Http\Request $request
  70. * @param \App\Models\WordIndex $wordIndex
  71. * @return \Illuminate\Http\Response
  72. */
  73. public function update(Request $request, WordIndex $wordIndex)
  74. {
  75. //
  76. }
  77. /**
  78. * Remove the specified resource from storage.
  79. *
  80. * @param \App\Models\WordIndex $wordIndex
  81. * @return \Illuminate\Http\Response
  82. */
  83. public function destroy(WordIndex $wordIndex)
  84. {
  85. //
  86. }
  87. }