使用Eloquent ['eləkwənt] 时,数据库查询构造器的方法对模型类也是也用的,使用上只是省略了DB::table('表名')
部分。
在模型中使用protected成员变量
$table
指定绑定的表名。
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Flight extends Model
{
/**
* The table associated with the model.
*
* @var string
*/
protected $table = 'my_flights';
}
Eloquent 假设每个表都有一个名为id
的主键,可以通过$primaryKey
成员变量覆盖该字段名称,另外,Eloquent假设主键字段是自增的整数,如果你想用非自增的主键或者非数字的主键的话,必须指定模型中的public属性$incrementing
为false。
默认情况下,Eloquent期望表中存在created_at
和updated_at
两个字段,字段类型为timestamp
,如果不希望这两个字段的话,设置$timestamps
为false
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Flight extends Model
{
/**
* Indicates if the model should be timestamped.
*
* @var bool
*/
public $timestamps = false;
/**
* The storage format of the model's date columns.
*
* @var string
*/
protected $dateFormat = 'U';
}
使用protected $connection = 'connection-name'
指定模型采用的数据库连接。
方法all
用于返回模型表中所有的结果
$flights = Flight::all();
foreach ($flights as $flight) {
echo $flight->name;
}
也可以使用get
方法为查询结果添加约束
$flights = App\Flight::where('active', 1)
->orderBy('name', 'desc')
->take(10)
->get();
可以看到,查询构造器的方法对模型类也是可以使用的
在eloquent ORM中,get
和all
方法查询出多个结果集,它们的返回值是一个Illuminate\Database\Eloquent\Collection
对象,该对象提供了多种对结果集操作的方法
public function find($key, $default = null);
public function contains($key, $value = null);
public function modelKeys();
public function diff($items)
...
该对象的方法有很多,这里只列出一小部分,更多方法参考API文档 Collection 和使用说明文档。
对大量结果分段处理,同样是使用chunk
方法
Flight::chunk(200, function ($flights) {
foreach ($flights as $flight) {
//
}
});
使用find
和first
方法查询单个结果,返回的是单个的模型实例
// 通过主键查询模型...
$flight = App\Flight::find(1);
// 使用约束...
$flight = App\Flight::where('active', 1)->first();
使用find
方法也可以返回多个结果,以Collection
对象的形式返回,参数为多个主键
$flights = App\Flight::find([1, 2, 3]);
如果查询不到结果的话,可以使用findOrFail
或者firstOrFail
方法,这两个方法在查询不到结果的时候会抛出Illuminate\Database\Eloquent\ModelNotFoundException
异常
$model = App\Flight::findOrFail(1);
$model = App\Flight::where('legs', '>', 100)->firstOrFail();
如果没有捕获这个异常的话,laravel会自动返回给用户一个404
的响应结果,因此如果希望找不到的时候返回404
,是可以直接使用该方法返回的
Route::get('/api/flights/{id}', function ($id) {
return App\Flight::findOrFail($id);
});
与查询构造器查询方法一样,可以使用聚集函数返回结果,常见的比如max
, min
,avg
,sum
,count
等
$count = App\Flight::where('active', 1)->count();
$max = App\Flight::where('active', 1)->max('price');
分页查询可以直接使用paginate
函数
LengthAwarePaginator paginate(
int $perPage = null,
array $columns = array('*'),
string $pageName = 'page',
int|null $page = null
)
参数说明
参数 | 类型 | 说明 |
---|---|---|
perPage | int | 每页显示数量 |
columns | array | 查询的列名 |
pageName | string | 页码参数名称 |
page | int | 当前页码 |
返回值为 LengthAwarePaginator 对象。
$limit = 20;
$page = 1;
return Enterprise::paginate($limit, ['*'], 'page', $page);
插入新的数据只需要创建一个新的模型实例,然后设置模型属性,最后调用save
方法即可
$flight = new Flight;
$flight->name = $request->name;
$flight->save();
在调用
save
方法的时候,会自动为created_at
和updated_at
字段设置时间戳,不需要手动指定
使用create
方法可以执行批量为模型的属性赋值的插入操作,该方法将会返回新插入的模型,在执行create
方法之前,需要先在模型中指定fillable
和guarded
属性,用于防止不合法的属性赋值(例如避免用户传入的is_admin属性被误录入数据表)。
指定$fillable
属性的目的是该属性指定的字段可以通过create
方法插入,其它的字段将被过滤掉,类似于白名单,而$guarded
则相反,类似于黑名单。
protected $fillable = ['name'];
// OR
protected $guarded = ['price'];
执行create
操作就只有白名单或者黑名单之外的字段可以更新了
$flight = App\Flight::create(['name' => 'Flight 10']);
除了create
方法,还有两外两个方法可以使用firstOrNew
和firstOrCreate
。
firstOrCreate
方法用来使用给定的列值对查询记录,如果查不到则插入新的。fristOrNew
与firstOrCreate
类似,不同在于如果不存在,它会返回一个新的模型对象,不过该模型是未经过持久化的,需要手动调用save
方法持久化到数据库。
// 使用属性检索flight,如果不存在则创建...
$flight = App\Flight::firstOrCreate(['name' => 'Flight 10']);
// 使用属性检索flight,如果不存在则创建一个模型实例...
$flight = App\Flight::firstOrNew(['name' => 'Flight 10']);
方法save
不仅可以要用来插入新的数据,也可以用来更新数据,只需先使用模型方法查询出要更新的数据,设置模型属性为新的值,然后再save
就可以更新了,updated_at
字段会自动更新。
$flight = App\Flight::find(1);
$flight->name = 'New Flight Name';
$flight->save();
也可使用update
方法对多个结果进行更新
App\Flight::where('active', 1)
->where('destination', 'San Diego')
->update(['delayed' => 1]);
使用delete
方法删除模型
$flight = App\Flight::find(1);
$flight->delete();
上述方法需要先查询出模型对象,然后再删除,也可以直接使用主键删除模型而不查询,使用destroy
方法
App\Flight::destroy(1);
App\Flight::destroy([1, 2, 3]);
App\Flight::destroy(1, 2, 3);
使用约束条件删除,返回删除的行数
$deletedRows = App\Flight::where('active', 0)->delete();
软删除是在表中增加deleted_at
字段,当删除记录的时候不会真实删除记录,而是设置该字段的时间戳,由Eloquent模型屏蔽已经设置该字段的数据。
要启用软删除,可以在模型中引用Illuminate\Database\Eloquent\SoftDeletes
这个Trait,并且在dates
属性中增加deleted_at
字段。
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
class Flight extends Model
{
use SoftDeletes;
/**
* The attributes that should be mutated to dates.
*
* @var array
*/
protected $dates = ['deleted_at'];
}
要判断一个模型是否被软删除了的话,可以使用trashed
方法
if ($flight->trashed()) {
//
}
如果模型被软删除了,普通查询是不会查询到该结果的,可以使用withTrashed
方法强制返回软删除的结果
$flights = App\Flight::withTrashed()
->where('account_id', 1)
->get();
// 关联操作中也可以使用
$flight->history()->withTrashed()->get();
$flights = App\Flight::onlyTrashed()
->where('airline_id', 1)
->get();
查询到软删除的模型实例之后,调用restore
方法还原
$flight->restore();
也可以在查询中使用
App\Flight::withTrashed()
->where('airline_id', 1)
->restore();
// 关联操作中也可以使用
$flight->history()->restore();
// Force deleting a single model instance...
$flight->forceDelete();
// Force deleting all related models...
$flight->history()->forceDelete();
上述操作后,数据会被真实删除。
参考:
京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。
日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。
据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。
今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。
日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。
近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。
据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。
9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...
9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。
据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。
特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。
据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。
近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。
据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。
9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。
《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。
近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。
社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”
2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。
罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。