php laravel model,如何使用 Laravel Eloquent Model

Laravel 框架 Eloquent Model

定义 Models

Models 一般放在 app 目录下,不过你可以将models放置在任何位置,只需可以根据 composer.json 文件实现自动加载即可。所有的 Eloquent models 都继承 Illuminate\Database\Eloquent\Model 类。

创建一个 model 实例,最简单的方式是使用 Artisan 命令 make:model ,如下:

php artisan make:model User

如果想要在生成一个 model 时,也生成一个数据库迁移(database migration),可以使用参数 --migration 或 -m:

php artisan make:model User --migration

php artisan make:model User -m

Eloquent Model 示例代码

下面是一个 Flight model class,可以用来接受和保存来自 filghts 数据库表的信息:

namespace App;

use Illuminate\Database\Eloquent\Model;

class Flight extends Model

{

//

}

设置指定表名

上面的 Flight model 中并没有指定使用哪一个表。除了指定一个表名,默认就使用的表名为“小写类名+s”。可以通过定义 model 中的 table 属性自定义表。

namespace App;

use Illuminate\Database\Eloquent\Model;

class Flight extent Model

{

// the table associated with the Model

// @var

protected $table = 'my_flights';

}

主键

Eloquent 默认设置每张表都有一个主键,名字是 id。你可以通过定义 $primaryKey 属性来重写主键名。

另外,默认主键是自增长的整型数字,可通过设置 public $incrementing 属性值为 false,使主键是非自增长的。

时间戳

默认,Eloquent 认为表中存在着 created_at 和 updated_at 。可以通过设置 $timestamp 属性为 false 而去掉。

namespace App;

use Illuminate\Database\Eloquent\Model;

class Flight extends Model

{

// indicates if the Model should be time stamped

// @var book

public $timestamps = false;

}

格式化时间戳,通过设置 $dateFormat 属性。

protected $dateFormat = 'U';

数据库链接

设置 $connection 属性

protected $connection = 'connection-name';

接受处理数据

namespace App\Http\Controllers;

use App\Flight;

use App\Http\Controllers\Controller;

class FlightController extends Controller

{

// show a list of all available flights

// @return Response

public function index()

{

$flights = Flight::all();

return view('flight.index', ['flights' => $flights]);

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值