亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Laravel 中每年的單獨表格

Laravel 中每年的單獨表格

PHP
幕布斯6054654 2022-07-02 16:57:31
在 Laravel 中如何實現基于年份的表格,如Orders2020,等Orders2019,Orders2018以及如何切換?
查看完整描述

3 回答

?
aluckdog

TA貢獻1847條經驗 獲得超7個贊

我有一個包含大量數據的模型,每個月它會生成近 1000 萬條以上的記錄,所以我也拆分了它的表格范圍。


解決方案如下所示,


在您的訂單模型中:

use Illuminate\Support\Carbon;


class Order extends Model

{

    protected $table = '';

    public function __construct($year='')

    {

        parent::__construct();


        if (empty($year)) {

            $tablename = 'orders'.Carbon::now()->year;

        } else {

            $tablename = 'orders'.$year;

        }

        $this->setTable($tablename);

    }

}

所以你可以得到你想要的表:


$orders2018 = new Order('2018');

$orders2018->where(...)->get();


$orders = Order::where(...)->get(); // will search from the table this year.


查看完整回答
反對 回復 2022-07-02
?
喵喔喔

TA貢獻1735條經驗 獲得超5個贊

我認為你可以做范圍


例子:


public function scopeYear($query,$year)

{

    $this->table = 'orders'.year;

    return $query;

}

  • 要從 orders2019 表中獲取,只需使用Order::year('2019')->get();

  • 要為 orders2019 表創建數據,只需使用Order::year('2019')->create($data);


查看完整回答
反對 回復 2022-07-02
?
有只小跳蛙

TA貢獻1824條經驗 獲得超8個贊

Order::from('orders_2019')->get();



查看完整回答
反對 回復 2022-07-02
  • 3 回答
  • 0 關注
  • 158 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號