Laravel數(shù)據(jù)庫(kù)操作的三種方式

一、數(shù)據(jù)庫(kù)操作之DB facade (跟使用原生sql操作沒(méi)什么區(qū)別)

1.查詢操作

$student=DB::select("select * from user");
// 返回一個(gè)二維數(shù)組  $student
var_dump($student);
// 以節(jié)點(diǎn)樹的形式輸出結(jié)果
dd($student);

2.新增操作

第一個(gè)參數(shù)是sql語(yǔ)句应又,第二個(gè)參數(shù)是一個(gè)數(shù)組,數(shù)組里的元素分別對(duì)應(yīng)sql語(yǔ)句里的問(wèn)號(hào)
$bool=DB::insert("insert into user(name,sex,age) values(?,?,?)",['小明','女',670]);
var_dump($bool);
// 新增成功則返回true喧锦。
  1. 更新操作
第一個(gè)參數(shù)是sql語(yǔ)句读规,第二個(gè)參數(shù)是一個(gè)數(shù)組,數(shù)組里的元素分別對(duì)應(yīng)sql語(yǔ)句里的問(wèn)號(hào)
$bool=DB::update('update user set age= ? where ID= ? ',[20,5]);
var_dump($bool); 
 //更新成功返回true
  1. 刪除操作
第一個(gè)參數(shù)是sql語(yǔ)句燃少,第二個(gè)參數(shù)是一個(gè)數(shù)組,數(shù)組里的元素分別對(duì)應(yīng)sql語(yǔ)句里的問(wèn)號(hào)
$num=DB::delete('delete from user where ID= ?',[5]);
echo $num;

二铃在、數(shù)據(jù)庫(kù)操作之查詢構(gòu)造器

1.查詢操作

// get()返回多條數(shù)據(jù)
$student=DB::table("user ")->get();
 var_dump($student);  
// first()返回1條數(shù)據(jù)
$student=DB::table("user ")->first();  //結(jié)果集第一條記錄
$student=DB::table("user ")->orderBy('ID','desc')->first();//按ID倒序排序
var_dump($student);  
// where()條件查詢
$student=DB::table("user ")->where('ID','>=',2)->get(); //一個(gè)條件   
$student=DB::table("user ")->whereRaw('ID> ? and age>= ?',[2,10])->get(); //多個(gè)條件
dd($student);
// pluck()指定字段,后面不加get
$student=DB::table("user ")->pluck('name');
dd($student);
// lists()指定字段阵具,可以指定某個(gè)字段作為下標(biāo)
$student=DB::table("user ")->lists('name','ID');   //指定ID為下標(biāo)
dd($student);
$student=DB::table("user ")->lists('name');   //不指定下標(biāo),默認(rèn)下標(biāo)從0開始
// select()指定某個(gè)字段
$student=DB::table("user ")->select('name','ID')->get();
dd($student);
// chunk()每次查n條
$student=DB::table("user ")->chunk(2,function($user){  //每次查2條
    var_dump($user);
    if(.......) return false;  //在滿足某個(gè)條件下使用return就不會(huì)再往下查了
});

# 使用聚合函數(shù)
// count()統(tǒng)計(jì)記錄條數(shù)
$nums=DB::table("user ")->count();
echo $nums;
// max()某個(gè)字段的最大值,同理min是最小值
$max=DB::table("user ")->max("age");
echo $max;
// avg()某個(gè)字段的平均值
$avg=DB::table("user ")->avg("age");
echo $avg;
// sum()某個(gè)字段的和
$sum=DB::table("user ")->sum("age");
echo $sum;

2.新增操作

$bool=DB::table("user")->insert(['name'=>'小明','sex'=>'女','age'=>20]);
echo $bool;  //返回bool值
 //如果想得到新增的id定铜,則使用insertGetId方法
  $id=DB::table("user")->insertGetId(['name'=>'小明','sex'=>'女','age'=>20]);
  echo $id;
 //插入多條數(shù)據(jù)
 $bool=DB::table("user")->insert([
        ['name'=>'小明','sex'=>'女','age'=>20],
        ['name'=>'小紅','sex'=>'男','age'=>21],
]);
echo $bool;  //返回bool值
  1. 更新操作
$bool=DB::table("user")->where('ID',6)->update(['age'=>30]);
echo $bool;
//自增
$bool=DB::table("user")->where('ID',6)->increment("age");// 年齡加1
$bool=DB::table("user")->where('ID',6)->increment("age",3);// 年齡加3
echo $bool;
//自減
$bool=DB::table("user")->where('ID',6)->decrement("age");// 年齡減1
$bool=DB::table("user")->where('ID',6)->decrement("age",3);// 年齡減3
echo $bool;
//自增時(shí)再修改其他字段
$bool=DB::table("user")->where('ID',6)->increment("age",3,['name'=>'小強(qiáng)']);// 年齡加3 名字改為小強(qiáng)
  1. 刪除操作
$num=DB::table("user")->where('ID',6)->delete();// 刪除1條
$num=DB::table("user")->where('ID','>',4)->delete();// 刪除多條
echo $num;  //刪除的行數(shù)
$num=DB::table("user")->truncate();// 刪除整表阳液,不能恢復(fù),謹(jǐn)慎使用

三揣炕、數(shù)據(jù)庫(kù)操作之 - Eloquent ORM

  1. 模型的建立及查詢數(shù)據(jù)
    laravel所自帶的Eloquent ORM 是一個(gè)ActiveRecord實(shí)現(xiàn)帘皿,用于數(shù)據(jù)庫(kù)操作。每個(gè)數(shù)據(jù)表都有一個(gè)與之對(duì)應(yīng)的模型畸陡,用于數(shù)據(jù)表交互鹰溜。
    建立模型,在app目錄下建立一個(gè)user模型丁恭,由于看習(xí)慣了mvc所以先建立一個(gè)Models文件夾在里面建立user.php曹动,目錄結(jié)構(gòu)變成 app/Models/user.php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
     /**
     * 指定表名
     * @var string
     */
    protected $table = 'e_user';
    /**
     * 指定id
     * @var string
     */
    protected $primarykey = 'id';
    /*
    * 自動(dòng)維護(hù)時(shí)間戳
    * 返回當(dāng)前時(shí)間戳
    */ 
    public $timestamps = true;
    protected function getDateFormat(){
        return time();
    }
    // 允許批量賦值的字段
    protected $fillable=['name','age','sex'];
    // 定義隱藏的字段
    protected $hidden = ['updated_at','created_at','deleted_at'];
}

在User控制器里增加一個(gè)test方法

public function test(){
      // all()方法查詢所有數(shù)據(jù)
      $users=User ::all();
      dd($users);
      //find()查詢一條,依據(jù)主鍵查詢牲览。findOrFail()查找不存在的記錄時(shí)會(huì)拋出異常
      $user=User ::find(5);  //主鍵為5的記錄
      var_dump($user);
      //查詢構(gòu)造器的使用,省略了指定表名
      $user=User::get();  
      var_dump($user);
      //使用leftjoin 進(jìn)行查詢
      Banner::where($where)
      ->leftJoin("c_img_url", function ($join){
           // 右表和左表相對(duì)應(yīng)的字段墓陈,可以有多個(gè)右表,直接把這一句復(fù)制改一下表名字段名就行了
           $join->on("c_img_url.id", "=", "c_banner.img_url_id"); 
      })->get(array('c_banner.*','c_img_url.address','c_img_url.name'))
    
}

2.新增數(shù)據(jù)第献、自定義時(shí)間戳贡必、批量賦值
laravel會(huì)默認(rèn)維護(hù)created_at,updated_at 兩個(gè)字段,這兩個(gè)字段都是存儲(chǔ)時(shí)間戳庸毫,整型11位的仔拟,因此使用時(shí)需要在數(shù)據(jù)庫(kù)添加這兩個(gè)字段。如果不需要這個(gè)功能岔绸,只需要在模型里加一個(gè)屬性:public $timestamps=false; 以及一個(gè)方法理逊,可以將當(dāng)前時(shí)間戳存到數(shù)據(jù)庫(kù)

(1)使用save方法新增
$student=new Student();
//設(shè)定數(shù)據(jù)
$student->name='xiaoming';
$student->age='18';
$student->sex='女';
$bool=$student->save();  //保存
echo $bool;

(2)使用create方法新增時(shí)恋拷,需要在模型里增加:
 //允許批量賦值的字段
protected $fillable=['name','age','sex'];  
// 在控制器中使用
Student::create(['name'=>'mmm','age'=>23,'sex'=>'女']);
// 這樣即可新增成功制轰!

(3)firstOrCreate()以屬性查找記錄,若沒(méi)有則新增
代碼執(zhí)行順序:先查找表中是否有name=phphub-monkey的吱七,如果有則不新增刚盈,沒(méi)有就新增
第一個(gè)參數(shù)用于確認(rèn) Eloquent 對(duì)象是否存在羡洛;
第二個(gè)參數(shù)用于生成 Eloquent 對(duì)象時(shí)需要附加生成的屬性。
$user = User::firstOrCreate(
    ['name' => 'phphub-monkey'],
    [
        'email' => 'jin114001251@gmail.com',
        'age' => '23',
        'sex' => 'nv',
    ]
]);

(4)firstOrNew()以屬性查找記錄,若沒(méi)有則會(huì)創(chuàng)建新的實(shí)例欲侮。若需要保存崭闲,則自己調(diào)用save方法()
和firstOrCreate類似只不過(guò)需要自己調(diào)用save()
$user=User::firstOrNew(['name'=>'小強(qiáng)']);
$user->save();
echo $user;
  1. 修改數(shù)據(jù)
//通過(guò)模型更新數(shù)據(jù)
$user=User::find(2); // 修改主鍵為2的數(shù)據(jù)
$user->age=25;
$user->save(); //返回bool值
//通過(guò)查詢構(gòu)造器更新
$num=User::where('ID','>',2)->update(['age'=>20]);
echo $num;  //返回更新的行數(shù)

updateOrCreate如果不存在就創(chuàng)建(和firstOrNew方法類似)
// 名字為小明的行是否存在,不存在就創(chuàng)建
User::updateOrCreate(
    ['name' => '小明'],
    [
        'age' => 20,
        'sex' => '女',
    ]);

  1. 刪除數(shù)據(jù)
(1) 通過(guò)模型刪除數(shù)據(jù)
$user=User::find(11);
$user->delete(); //返回bool值

(2) 通過(guò)主鍵刪除
 $num=User::destroy(10); //刪除主鍵為10的一條記錄
 echo $num; //返回刪除的行數(shù)
 $num=User::destroy(10,5); //刪除多條  或者$num=Student::destroy([10,5]);
 echo $num; //返回刪除的行數(shù)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末威蕉,一起剝皮案震驚了整個(gè)濱河市刁俭,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌韧涨,老刑警劉巖牍戚,帶你破解...
    沈念sama閱讀 218,607評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異虑粥,居然都是意外死亡如孝,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門娩贷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)第晰,“玉大人,你說(shuō)我怎么就攤上這事彬祖∽率荩” “怎么了?”我有些...
    開封第一講書人閱讀 164,960評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵涧至,是天一觀的道長(zhǎng)腹躁。 經(jīng)常有香客問(wèn)我,道長(zhǎng)南蓬,這世上最難降的妖魔是什么纺非? 我笑而不...
    開封第一講書人閱讀 58,750評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮赘方,結(jié)果婚禮上烧颖,老公的妹妹穿的比我還像新娘。我一直安慰自己窄陡,他們只是感情好炕淮,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著跳夭,像睡著了一般涂圆。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上币叹,一...
    開封第一講書人閱讀 51,604評(píng)論 1 305
  • 那天润歉,我揣著相機(jī)與錄音,去河邊找鬼颈抚。 笑死踩衩,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播驱富,決...
    沈念sama閱讀 40,347評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼锚赤,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了褐鸥?” 一聲冷哼從身側(cè)響起线脚,我...
    開封第一講書人閱讀 39,253評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎晶疼,沒(méi)想到半個(gè)月后酒贬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,702評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡翠霍,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蠢莺。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片寒匙。...
    茶點(diǎn)故事閱讀 40,015評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖躏将,靈堂內(nèi)的尸體忽然破棺而出锄弱,到底是詐尸還是另有隱情,我是刑警寧澤祸憋,帶...
    沈念sama閱讀 35,734評(píng)論 5 346
  • 正文 年R本政府宣布会宪,位于F島的核電站,受9級(jí)特大地震影響蚯窥,放射性物質(zhì)發(fā)生泄漏掸鹅。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評(píng)論 3 330
  • 文/蒙蒙 一拦赠、第九天 我趴在偏房一處隱蔽的房頂上張望巍沙。 院中可真熱鬧,春花似錦荷鼠、人聲如沸句携。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)矮嫉。三九已至,卻和暖如春牍疏,著一層夾襖步出監(jiān)牢的瞬間蠢笋,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工麸澜, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留挺尿,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,216評(píng)論 3 371
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像编矾,于是被迫代替她去往敵國(guó)和親熟史。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Laravel提供了3種操作數(shù)據(jù)庫(kù)方式:DB facade(原始方式)窄俏、查詢構(gòu)造器和Eloquent ORM蹂匹。數(shù)據(jù)...
    碼課sir閱讀 13,196評(píng)論 0 5
  • 關(guān)于Mongodb的全面總結(jié) MongoDB的內(nèi)部構(gòu)造《MongoDB The Definitive Guide》...
    中v中閱讀 31,938評(píng)論 2 89
  • Laravel框架一:原理機(jī)制篇 Laravel作為在國(guó)內(nèi)國(guó)外都頗為流行的PHP框架,風(fēng)格優(yōu)雅凹蜈,其擁有自己的一些特...
    Mr_Z_Heng閱讀 3,694評(píng)論 0 13
  • 原文鏈接 必備品 文檔:Documentation API:API Reference 視頻:Laracasts ...
    layjoy閱讀 8,607評(píng)論 0 121
  • 今天是什么日子 起床:六點(diǎn)多 就寢:九點(diǎn)多 天氣:晴 心情:還好啦 紀(jì)念日:開學(xué)第一天 帶我媽去看了新食堂哈哈 任...
    趙齊齊的小龍貓閱讀 198評(píng)論 0 0