首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

跟我一起学Laravel-EloquentORM基础部分

使用Eloquent [‘eləkwənt] 时,数据库查询构造器的方法对模型类也是也用的,使用上只是省略了DB::table('表名')部分。...$primaryKey成员变量覆盖该字段名称,另外,Eloquent假设主键字段是自增的整数,如果你想用非自增的主键或者非数字的主键的话,必须指定模型中的public属性$incrementing为false...) ->take(10) ->get(); 可以看到,查询构造器的方法对模型类也是可以使用的 在eloquent ORM中,get和all方法查询出多个结果集,它们的返回值是一个Illuminate...与查询构造器查询方法一样,可以使用聚集函数返回结果,常见的比如max, min,avg,sum,count等 $count = App\Flight::where('active', 1)->count...,当删除记录的时候不会真实删除记录,而是设置该字段的时间戳,由Eloquent模型屏蔽已经设置该字段的数据。

85220

通过 Laravel Eloquent 模型实现批量赋值和软删除

在介绍批量赋值之前,我们先看一个例子,之前我们新增或者修改 Eloquent 模型时都是通过依次设置每个属性来实现的: $post = new App\Post; $post->title = '测试文章标题...创建模型 以创建模型实例为例,批量赋值允许我们以数组的方式将待设置属性以关联数组的方式传递构造函数: $post = new Post([ 'title' => '测试文章标题', '...更新模型 如果是更新模型类,也可以通过批量赋值的方式实现,只需在获取模型类后使用 fill 方法批量填充属性即可: $post = Post::findOrFail(11); $post->fill($...其底层实现原理是在支持软删除的数据表中添加一个 deleted_at 字段,这可以通过数据库迁移来实现。...该字段默认值为 NULL,表示没有被软删除。如果要在模型类中支持软删除,需要在对应模型类(在本例中是 Post 模型)中添加支持软删除的 Trait: <?

2.5K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Laravel学习记录--Model

    ,无法显示结果。...$name:关联关系的名称 $type:根据关联名称拼接存放关联类的字段,也可自定义 $id:根据关联名称拼接存放关联类的id .也可自定义 $localKey:当前模型的主键id public function...在调用save方法向Phone模型插入值 这里Eloquent自动在phones表中添加了uid字段,并插入正确的值 使用saveMany添加多个值 $user = \App\Muser::find...,如果不允许为空会抛出异常 空对象模型 如果外键字段uid允许为空,当我们访问Phone模型上的muser属性(注意这里是属性,而不是方法)时,默认返回null,Eloquent允许我们为这种空对象定义一个默认的类型...'=>'额外字段值']]) 同步关联 使用sync方法构造多对多关联,sync方法接受ID数组,向中间表插入对应关联数据记录,在这里没有被放在数组里的id会从中间表移除。

    13.6K20

    Laravel框架关键技术解析

    、模型文件等 bootstrap:主要包含几个框架启动和自动加载配置的文件 config:主要包含应用程序常用的配置文件信息 database:主要包含数据库迁移和数据库填充文件 public:为应用程序的入口目录...,这里需要与composer的自动加载类进行区别;二是完成外观自动加载类中的自动加载函数的添加。...1.两个阶段 Eloquent ORM查询构造器的生成,Illuminate\Database\Eloquent\Model::newQuery() 操作命令的执行,Illuminate\Database...\Eloquent\Builder 2.ORM映射最大的好处是将数据表的结构映射成一个类对象,可以将数据以对象的形式封装使用,程序的编写将变得高效而且结构清晰 3.对于多个表而且表间存在不同的关系时,如果使用不好会严重影响程序的性能...通过中间件StartSession开启会话 2.根据sessionID来恢复之前 存储的数据,在请求处理期间可以使用恢复的数据,同时也可以向session中继续添加或删除数据。

    12K20

    【Laravel系列4.3】模型Eloquent ORM的使用(一)

    对于 Laravel 中标准的 Eloquent 模型类来说,每个表都应该有两个字段,一个是 updated_at ,另一个是 created_at ,分别是两个时间戳字段,用于记录数据的创建时间和修改时间...最后在查询中,我们也看到了类似于 查询构造器 的链式调用形式,通过模型的静态 where() 方法返回的实例对象,一步步地构造整个查询。...db_sex 表的模型,这个表是上篇文章中测试时使用的,就直接拿来使用了。...在这个方法中,第一个参数是指定要关联的模型,第二个参数是对应的字段。belongsTo 这个单词是什么意思呢?...下篇文章我们还将继续进行模型的学习以及整个模型的源码分析。 参考文档: https://learnku.com/docs/laravel/8.x/eloquent/9406

    8.9K20

    3分钟短文:Laravel ORM 模型用法纲要

    创建一个模型类非常简单,只用继承系统的模型就可以了: use Illuminate\Database\Eloquent\Model; class Contact extends Model {} 因为遵循的是约定大于配置的惯例...$request->input('email'); $contact->save(); return redirect('contacts'); } 创建一个合约,并使用传入的表单数据填充...所以使用map遍历集合元素时, 每个元素其实都是一个独立的Contact对象,直接给对象追加属性就可以增加字段了。...等等标准字段,而在数据库表的字段默认值内允许为NULL,或者默认为NULL。...你想要他们自动更新为当前系统时间,只需要添加这个配置项: public $timestamps = false; 存储的日期时间格式,也可以自定义: protected $dateFormat = 'Ymd

    74740

    Laravel5.2之Demo1——URL生成和存储

    创建Form表单 (1)、在resources/views/文件夹下创建一个urls文件夹,在urls文件夹下创建一个form.blade.php文件文件名需要有blade字符串,laravel会自动识别这个文件为...《Modern PHP》(可以去pan.java1234.com搜到英文版的)这本书中倡导PHP软件开发应该使用组件components方式来做,利用别人的轮子会加速开发效率,组件components可装可卸...不过有时也推荐使用它的Query Builder查询构造器,实际上就是SQL语句封装的类,性能会比较高一些,个人遇到过一个场景:使用Eloquent ORM性能有点慢,导致PHP执行过长报503 Time...withInput()函数会在返回表单时在input里填上刚刚输入的旧数据。...Hash::make( else{ $newHash = Hash::make(Input::get('link'));//根据输入的link做hash哈希就行或者别的更简短的输入值 } (4).向link

    24.1K31

    Laravel 7发行说明

    Laravel 现在提供一套围绕 Guzzle HTTP 客户端](http://docs.guzzlephp.org/en/stable/) 构建的精简且高效的 API,允许你快速向其它 web 应用发起...你可能对 Laravel 已有的 Illuminate\Support\Str 这个类比较熟悉,它提供了各种有用的字符串操作函数。...路由模型绑定优化 路由模型绑定优化由 Taylor Otwell 开发贡献 。 自定义键名 有时你可能希望使用 id 以外的字段来解析 Eloquent 模型。...$post; }); 隐式绑定约束 有时,当在路由中隐式绑定多个 Eloquent 模型时,可能希望对第二个 Eloquent 模型进行约束,使其必须是第一个 Eloquent 模型的子类。...这些类是根据输入填充值使用「桩代码」生成文件的。 但是,有时可能希望对 Artisan 生成的文件进行小的更改。

    9K20

    Laravel Eloquent 模型关联关系详解(上)

    到目前为止,我们介绍的所有 Eloquent 模型操作都是针对单表的,接下来我们将花三篇左右的篇幅来给大家介绍如何在 Eloquent 模型类中建立模型之间的各种关联关系,以及如何实现关联查询和更新。...(UserProfile::class); } 我们通过数据库填充技术在 user_profiles 插入一些数据,这样就可以在 User 模型实例上通过关联方法名作为动态属性访问与其对应的 UserProfile...你可能注意到了我们在定义关联关系时,仅仅指定了模型类名,并没有指定通过哪些数据表字段建立关联,这并不是说 Laravel 神通广大,能知过去未来之事,而是因为 Eloquent 对此做了默认的约定。...return $this->belongsToMany(Tag::class, 'post_tags'); } 通过数据库填充器填充一些数据到 tags 表和 post_tags 表,这样我们就可以通过关联查询查询指定...Eloquent 还提供了方法允许你获取中间表的字段,你仔细看查询结果字段,会发现 relations 字段中有一个 pivot 属性,中间表字段就存放在这个属性对象上: 我们在遍历返回结果的时候可以在循环中通过

    10K40

    跟我一起学Laravel-EloquentORM进阶部分

    ,定义好之后,可以使用下列语法查询到关联属性了 $phone = User::find(1)->phone; Eloquent会假定关联的外键是基于模型名称的,因此Phone模型会自动使用user_id...关联关系查询 在Eloquent中,所有的关系都是使用函数定义的,可以在不执行关联查询的情况下获取关联的实例。...()->where('active', 1)->get(); 如果不需要对关联的属性添加约束,可以直接作为模型的属性访问,例如上面的例子,我们可以使用下面的方式访问User的Post $user = App...belongsTo关系的话,使用dissociate方法 $user->account()->dissociate(); $user->save(); Many to Many 关系 中间表查询条件 当查询时需要对使用中间表作为查询条件时...$user->roles()->attach($roleId); // 为用户添加角色,更新中间表的expires字段 $user->roles()->attach($roleId, ['expires

    4K50
    领券