濮阳杆衣贸易有限公司

主頁 > 知識庫 > Laravel框架Eloquent ORM簡介、模型建立及查詢數(shù)據(jù)操作詳解

Laravel框架Eloquent ORM簡介、模型建立及查詢數(shù)據(jù)操作詳解

熱門標簽:騰訊外呼管理系統(tǒng) 青島語音外呼系統(tǒng)招商 岳陽外呼型呼叫中心系統(tǒng)在哪里 百應電話機器人服務 揚州地圖標注app 山西探意電話機器人 山西回撥外呼系統(tǒng) 河南電銷卡外呼系統(tǒng)哪家強 昭通辦理400電話

本文實例講述了Laravel框架Eloquent ORM簡介、模型建立及查詢數(shù)據(jù)操作。分享給大家供大家參考,具體如下:

注:以下知識點可能有不全面之處,望見諒

NO.1Eloquent ORM簡介

Laravel所自帶的Eloquent ORM是一個優(yōu)美、簡潔的ActiveRecord實現(xiàn),用來實現(xiàn)數(shù)據(jù)庫操作
每個數(shù)據(jù)表都有與之相對應的“模型(Model)”用于和數(shù)據(jù)交互

NO.2模型的建立

最基礎的模型代碼如下:

namespace App;
use Illuminate\Database\Eloquent\Model;
class Student extends Model
{
 //指定表名
 protected $table = 'student';
 //指定id
 protected $primaryKey = 'id';
}

將他創(chuàng)建于app目錄下,命名為Student.php

NO.3查詢數(shù)據(jù)

首先在查詢之前,我先讓你們看一下我的數(shù)據(jù)庫

數(shù)據(jù)如上,然后查詢

1.all方式

代碼如下:

namespace App\Http\Controllers;
use App\Student;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller
{
 public function orm1()
  {
      $students = Student::all();
      dd($students);
 }
}

顯示數(shù)據(jù)庫里的所有數(shù)據(jù)

2.find方式

代碼如下:

namespace App\Http\Controllers;
use App\Student;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller
{
 public function orm1()
  {
      $students = Student::find(1);
      dd($students);
 }
}

查找指定數(shù)據(jù)

3.findOrFail方式

代碼如下:

namespace App\Http\Controllers;
use App\Student;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller
{
 public function orm1()
  {
      $students = Student::findOrFail(1);
      dd($students);
 }
}

如果他沒查到指定的數(shù)據(jù),那么他會報錯,而find若是沒有查到該函數(shù),只會彈出一個null

4.查詢構造器的使用

  • 1.get方式使用
namespace App\Http\Controllers;
use App\Student;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller
{
 public function orm1()
  {
      $students = Student::get();
      dd($students);
 }
}

他會得到一個完整的數(shù)據(jù)信息,和原本的意義沒有區(qū)別

  • 2.first方式使用

代碼如下:

namespace App\Http\Controllers;
use App\Student;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller
{
 public function orm1()
  {
     $student = Student::where('id','>',1)
     ->orderBy('age','desc')
     ->first();
     dd($student);
 }
}

當id大于一的時候,獲取一個最大值的age

  • 3.where方式使用

代碼如下:

namespace App\Http\Controllers;
use App\Student;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller
{
 public function orm1()
  {
     $student = Student::where('id','>',1)
     ->get();
     dd($student);
 }
}

  • 4.chunk方式使用

代碼如下:

namespace App\Http\Controllers;
use App\Student;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller
{
 public function orm1()
  {
     $student = Student::chunck(2,function($student){
  var_dump($student);
 });
 }
}

5.聚合函數(shù)的使用

  • 1.count函數(shù)

代碼如下:

namespace App\Http\Controllers;
use App\Student;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller
{
 public function orm1()
  {
     $student = Student::count();
     dd($student);
 }
}

  • 2.max函數(shù)

代碼如下:

namespace App\Http\Controllers;
use App\Student;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller
{
 public function orm1()
  {
     $student = Student::max('age');
     dd($student);
 }
}

  • 3.min函數(shù)

代碼如下:

namespace App\Http\Controllers;
use App\Student;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller
{
 public function orm1()
  {
     $student = Student::min('age');
     dd($student);
 }
}

  • 4.avg函數(shù)

代碼如下:

namespace App\Http\Controllers;
use App\Student;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller
{
 public function orm1()
  {
     $student = Student::avg('age');
     dd($student);
 }
}

  • 5.sum函數(shù)

代碼如下:

namespace App\Http\Controllers;
use App\Student;
use Illuminate\Support\Facades\DB;
class StudentController extends Controller
{
 public function orm1()
  {
     $student = Student::sum('age');
     dd($student);
 }
}

更多關于Laravel相關內容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優(yōu)秀開發(fā)框架總結》、《php面向對象程序設計入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對大家基于Laravel框架的PHP程序設計有所幫助。

您可能感興趣的文章:
  • django框架面向對象ORM模型繼承用法實例分析
  • MySql用DATE_FORMAT截取DateTime字段的日期值
  • mysql數(shù)據(jù)庫中的information_schema和mysql可以刪除嗎?
  • ORM模型框架操作mysql數(shù)據(jù)庫的方法

標簽:寶雞 婁底 南陽 湛江 宜賓 黃南 銅川 鎮(zhèn)江

巨人網(wǎng)絡通訊聲明:本文標題《Laravel框架Eloquent ORM簡介、模型建立及查詢數(shù)據(jù)操作詳解》,本文關鍵詞  Laravel,框架,Eloquent,ORM,簡介,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Laravel框架Eloquent ORM簡介、模型建立及查詢數(shù)據(jù)操作詳解》相關的同類信息!
  • 本頁收集關于Laravel框架Eloquent ORM簡介、模型建立及查詢數(shù)據(jù)操作詳解的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    浠水县| 九龙坡区| 曲阳县| 卓尼县| 浦江县| 周口市| 定安县| 雷山县| 贵南县| 巴南区| 开远市| 曲靖市| 长顺县| 广宗县| 延长县| 乌什县| 清远市| 大田县| 青龙| 岗巴县| 鄱阳县| 洱源县| 肃宁县| 黎川县| 赫章县| 侯马市| 乌兰察布市| 揭东县| 镇坪县| 中超| 安康市| 玛沁县| 庆城县| 平邑县| 洪湖市| 休宁县| 扶沟县| 温州市| 海伦市| 通许县| 如东县|