软删除 在许多情况下,你不会真正想要从数据库中删除记录,而是用一种不再在应用程序中显示它们的方式对其进行注释。这就是所谓的软删除。...Laravel本身支持软删除,只需要进行少量的配置更改,以确保在执行delete或destroy时,模型的记录不会被实际删除。作为一个例子,我们修改Event模型以支持软删除。...首先创建一个新的迁移,将名为deleted_at的列添加到events表中: php artisan make:migration add_soft_delete_to_events --table=events...其实原理很简单,就是为模型追加一个全局作用域,为每个查询子句追加上如下筛选条件: WHERE deleted_at IS NULL laravel已经为我们写好这部分逻辑了,在模型内引入如下trait:...任何设置deleted_at为日期时间值的记录,都不会包含在任何查询结果中,因此看起来已经被删除了。
`deleted_at` IS NULL fmt.Println(result.RowsAffected) // 返回找到的记录计数,等于“len(student)” fmt.Println(result.Error...`deleted_at` IS NULL 若要在查询条件中包含零值,可以使用map,该映射将包含所有键值作为查询条件,例如: // 如果想要在查询中包含0的字段,可以使用map来做 db.Where...`id` = 25 2.4.4 内联条件 查询条件可以以类似于Where的方式内联到'First'和'Find'等方法中 // 如果是非整形主键,根据主键获取记录 db.First(&Student{...name LIKE "name%") 3.4 From 子查询 GORM 允许您在 Table 方法中通过 FROM 子句使用子查询,例如: db.Table("(?)...`deleted_at` IS NULL // 可以看到Name字段不会更新,这是合理的,因为如果零值字段也更新,Student表中好多数据都会被更新为空 6.1 使用sql.NullString更新
有时候,我们想要获取的并不是一行或几行记录,而是某个字段的值,你当然你可以查询到一行记录后从结果对象中获取指定字段的值,但是 Laravel 为我们提供了更便捷的语法: $name = '学院君'; $...你一定有过这样的经历,从数据库获取指定查询结果后,以主键 ID 值为键,以某个字段值为值构建关联数组,以前,你可能不得不遍历查询结果构建数组才能解决这样的问题,在 Laravel 中,我们只需在查询构建器上调用...null查询 NULL 查询就是判断某个字段是否为空的查询,Laravel 查询构建器为我们提供了 whereNull 方法用于实现该查询: DB::table('users')->whereNull(...where 条件子句,它将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积,如果带 where,返回的是匹配的行数。...不是每个用户都有对应的 posts 记录,所以会出现某些 posts 记录为空的结果: ?
另外,如果访问的是模型实例上的 author() 方法时,返回的不是用户实例了,而是一个关联关系实例,该实例注入了查询构建器,所以你可以在其基础上通过方法链的方式构建查询构建器进行更加复杂的查询,我们以一个一对多的查询为例...', function ($query) { $query->where('title', 'like', 'Laravel学院%'); })->get(); 底层执行的 SQL 查询语句如下...前提是 user_id 允许为 null,否则会抛出异常。 空对象模型 如果外键字段 user_id 允许为空的话,当我们访问 Post 模型上的 author 属性时,默认返回为 null。...author 属性时,就会返回如下默认的空对象了: 该特性其实应用了设计模式中的空对象模式,好处是在代码里可以为不同情况编写一致性代码。...这样,我们就不需要在每个地方去判断如果文章作者信息为空该如何处理了,因为这种情况下返回的也是一个正常的 User 模型实例。
那么直接给 $guarded 赋值为空数组就等于没有任何限制了 /** * 不可批量赋值的属性。...create 方法的返回值就是当前插入到数据库中的内容up可以通过返回值判断成功或者失败而实际开发中up经常需要返回新增数据的id那直接访问返回值的 id 属性即可。...数据中一眼就发现了后三条数据的不同,我们之前用 DB 插入到数据库中的数据 created_at 和 updated_at 字段都是空,而我们用模型插入和修改后 created_at 和 updated_at...当时我希望能有一个恢复删除的功能比如说回收站,laravel 的模型为我们提供了很方便的软删除功能 要启用软删除首先数据表需要有 deleted_at 字段 之前玩迁移的时候简单的说了下创建迁移的时候调用...属性转换成 DateTime / Carbon 实例 当然,你需要把 deleted_at 字段添加到数据表中。
2.1 准备工作 如果你要实现软删除 你应该提前做3件事情: 添加deleted_at 到模型的 $date 属性中。...在模型中使用 Illuminate\Database\Eloquent\SoftDeletes 这个trait 保证你的数据表中有deleted_at列 如果没有就添加这个列。...deleted_at 不为空 它是一个时间值,当delete_at不为空时 证明这条数据已经被软删除了。...它会自动从查询数据中排除、就是它无法被一般的查询语句查询到。...》 希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
大家注意那个 IN 子句,其实是一个查询结果集,从另个表返回的。 写SQL真的很伤神,不如用框架自带的orm,操作起来非常人性化,拼装也很简单。那就抛出一个问题,Laravel如何实现上述的子查询?...对Laravel来说,简直不要太简单,你只要在写whereIn的时候,将数组使用闭包返回就可以了。...->where('active', 1); }) ->get(); 这样使用 DB::raw,还有 whereRaw 方法,你几乎就是在写原生的SQL语句了。比较直观。...写在最后 本文通过一个SQL语句查询在Laravel中的实现方式,解释了laravel在拼装SQL查询时的自由度,使用起来非常灵活。...对于固定的查询方式,或者经过优化的SQL语句,你大可直接发送给Laravel直接运行以便提高效率。
Laravel 5.5 Linux mint 18 PHPStorm 最近刚玩Laravel,手册源码还没来得及看完就跃跃欲试做了个小项目,其中有个需求是分组查询数据库中的一个字段并返回每个分组中的数量...having 方法的用法和 where 方法类似: $users = DB::table('users') - groupBy('account_id') - having('account_id...这时可使用 select 方法自定义一个 select 子句来查询指定的字段: $users = DB::table('users')- select('name', 'email as user_email...('count(*) as value'); 我用了个Data(Model),返回的是个Builder对象,而此处却要一个字符串,所以改回了 $sql = DB::raw('count(*) as value...参考: Laravel Eloquent groupBy() AND also return count of each group 以上这篇Laravel 实现Eloquent模型分组查询并返回每个分组的数量
::table('articles')- avg('comment_count'); dd($commentAvg); } 1.5 select查询 1.5.1 自定义子句 select语句可以获取指定的列...语句 where语句是比较常用的,经常用他来进行条件筛选。...,8的集合,不过我们数据库中只有id为1和3的数据 那么它只会返回id为1和3的集合。...为空的集合。...('created_at')- get(); dd($articles); } ↑ 上述代码中是查找created_at不为空的集合。
* * @var array */ protected $guarded = ['price']; } 如果你想要让所有属性都是可批量赋值的,可以将 $guarded 属性设置为空数组:...当模型被软删除后,它们并没有真的从数据库删除,而是在模型上设置一个 deleted_at 属性并插入数据库,如果模型有一个非空 deleted_at 值,那么该模型已经被软删除了。...* * @var array */ protected $dates = ['deleted_at']; } 当然,应该添加 deleted_at 列到数据表。...需要的话可以在 apply 方法中添加 where 条件到查询: <?...注:如果你的全局作用域需要添加列到查询的 select 子句,需要使用 addSelect 方法来替代 select,这样就可以避免已存在的 select 查询子句造成影响。
其实就像我们上篇文章中学习过的使用原始 SQL 语句的方式来操作数据库一样,查询构造器这个东西就是在这个原始操作的基础上为我们封装了一系列的接口,能够让我们方便地来操作数据库。...或者说,就是像我们很早前自己封装的那种 MySQL 类一样,框架帮我们完成了这一步。并且,最主要的是,它可以让我们以链式调用的形式来操作数据库,从而避免去写繁杂混乱的 SQL 语句。...查询语句相对来说会复杂一些,我们在测试代码中增加了 where() 、orderBy() 和分页相关的组织函数。最后,通过一个 get() 函数就可以获得列表的信息。...注意看我注释掉的第二种多条件的写法,在这里面我使用了 orOn() 和 where() ,大家可以打开测试一下,结果是如下的 SQL 语句。...好了,你可以继续查看这个类中的其它方法,可以发现 where() 、join() 这类的方法返回的都是 this ,通过这种返回 自身对象 的方式就可以继续链式调用,通过它们,我们就可以不断的为这个类中相对应的属性添加内容
列(column) 表中的一个字段,所有表都是有一个和 多个列组成 行(row) 表中的一个记录(record) 主键(primary key) 一列(或一组列),其值能够唯一标识表中每一行 关键字(...关键字不能用作表或者列的名字 子句(clause) SQL 语句由子句构成,有些子句是必需的,有些则是可选的 一些规则 多条 SQL 语句必须以分号分隔。...SQL 一般返回原始的、无格式的数据。 第一个检索的行是第 0 行,而不是第 1 行。 并非所有 SQL 实现方式 都一样。虽然基本的语句容易移植,但是较复杂的语句会有区别。...,应该保证它是 SELECT 语句中的最后一条子句。...NULL 表示空值,确定是否空值,不能简单的 = NULL,SELECT 语句有一个特殊的 WHERE 子句 IS NULL ,可用来检查具有 NULL 值的列。
) $data = DB::table('users')- get(); //first() 方法将会返回单个对象(获取一行一列) //where() 方法查询指定条件对象 $data = DB::table...select('id','name', 'email')- get(); //value() 方法从结果中获取单个值,该方法会直接返回指定列的值: $data = DB::table('users')...; //count() 统计数量 $data = DB::table('users')- count(); //exists() 方法来判断匹配查询条件的结果是否存在 $data=DB::table('...', 'like', '测试%') - get(); //传递条件数组到where中写法,建议多where查询使用这个方法 $data = DB::table('users') - where([ ['...方法添加查询参数到分页链接查询字符串; 添加 &name=$namePage到每个分页链接中. {{ $data- appends(['name' = $namePage])- links() }}
)自动添加到mod文件中。...,并且会更改现有列的类型(如果其大小、精度、是否为空可更改)。...但 不会 删除未使用的列,以保护您的数据。..., 241859).Delete(&Funtester{}) fmt.Println(db.RowsAffected) } 执行SQL 当然gorm也是支持直接执行SQL语句的,有一个特殊就是执行查询语句的时候需要解析查询结果...fmt.Println(funtester) } 事务&回滚 在gorm高级语法的使用中,我觉得这个是非常实用的,对于一些测试语句的执行非常适合。
` ,因为主键为空db.Create(&user)db.NewRecord(user) // => 在 `user` 之后创建返回 `false`默认值你可以通过标签定义字段的默认值,例如:type Animal...{ scope.SetColumn("ID", uuid.New()) return nil}创建额外选项// 为插入 SQL 语句添加额外选项db.Set("gorm:insert_option...": 20})//// SELECT * FROM users WHERE age = 20;额外的查询选项// 为查询 SQL 添加额外的选项db.Set("gorm:query_option", "...// 在更新 SQL 语句中添加额外的 SQL 选项db.Model(&user).Set("gorm:update_option", "OPTION (OPTIMIZE FOR UNKNOWN)")....// 删除一条存在的记录db.Delete(&email)//// DELETE from emails where id=10;// 为删除 SQL 语句添加额外选项db.Set("gorm:delete_option
创建模型 以创建模型实例为例,批量赋值允许我们以数组的方式将待设置属性以关联数组的方式传递构造函数: $post = new Post([ 'title' => '测试文章标题', '...Eloquent 模型类默认白名单属性为空,黑名单属性为 *,即所有字段都不会应用批量赋值: /** * 使用批量赋值的属性(白名单) * * @var array */ protected $...实现原理 Eloquent 模型类为我们提供了「软删除」功能的支持。这就意味着,在 Laravel 中,我们不需要编写任何额外代码就可以实现对数据库记录的「软删除」。...其底层实现原理是在支持软删除的数据表中添加一个 deleted_at 字段,这可以通过数据库迁移来实现。...该字段默认值为 NULL,表示没有被软删除。如果要在模型类中支持软删除,需要在对应模型类(在本例中是 Post 模型)中添加支持软删除的 Trait: <?
Laravel 框架中的 DB 和 ORM 是两个不同的组件,关于 ORM 的概念,我们也将在相关的学习中了解到,但是现在我们先从简单的普通查询学起。...这种操作其实就像是 Laravel 为我们封装好了 PDO 的调用,也就是像我们在很早前自己封装的那种数据库调用类一样,非常简单方便。...在代码中,我们通过 DB 这个门面类的 insert() 方法,就可以实现原生语句的增加操作。对于路由来说,其实我们不用写完全限定命名空间的类名,直接写个 DB 也是可以的。...注意,insert() 方法返回的结果是一个布尔值,也就是添加操作的成功失败情况,如果我们想获取新增加的数据的 id ,需要使用 DB::getPdo()->lastInsertId(); 这条语句才可以获取到...首先,我们新建一个数据库,就叫 laravel8 好了,并且同样的建立一个 raw_test 表,然后就是在 .env 中配置这个数据库的连接信息。
前言 近期在刷新生产环境数据库的时候,需要更新表中的字段,如果对每条数据结果都执行一次update语句,占用的数据库资源就会很多,而且速度慢。...因为项目是Laravel框架,Laravel有批量插入的方法,却没有批量更新的方法,没办法只能自己实现。...即是将条件语句写在了一起。 这里的where部分不影响代码的执行,但是会提高sql执行的效率。 确保sql语句仅执行需要修改的行数,这里只有3条数据进行更新,而where子句确保只有3行数据执行。...if (empty($multipleData)) { Log::info("批量更新数据为空"); return false; } $tableName = $this...$whereIn . ")"; Log::info($updateSql); // 传入预处理sql语句和对应绑定数据 return DB::update($updateSql, $bindings
这个就是坑1 查询单个记录时使用了TableName()返回的表名,而在查询结果为Array时,表名在TableName()的基础上又添加了前缀。...方法gorm.Open()返回的值类型就是这个结构体指针。 type Scope struct (gorm/scope.go) 当前数据库操作的信息,每次添加条件时也会创建clone对象。...inlineCondition(where...).callCallbacks(s.parent.callbacks.queries).db } Callback结构体中定义queries为函数指针数组...db.First(&product, 1)的值类型为结构体的指针*Product,而db.Find(&products)的值类型是数组的指针*[]Product, 从而导致db.Find(&products...s.defaultTableName为空值时先进行求值,reflect.New(s.ModelType).Interface().
新增数据、自定义时间戳、批量赋值 (1)使用save方法新增 laravel会默认维护created_at,updated_at 两个字段,这两个字段都是存储时间戳,整型11位的,因此使用时需要在数据库添加这两个字段...(4)firstOrNew()以属性查找记录,若没有则会创建新的实例。...where('vip_ID',' ',2)- update(['vip_fenshu'= 2000]); echo $num; //返回更新的行数 4....::destroy(10); //删除主键为10的一条记录 echo $num; //返回删除的行数 $num=Student::destroy(10,5); //删除多条 或者$num=Student...::destroy([10,5]); echo $num; //返回删除的行数 视频资源学习参考:http://www.imooc.com/learn/697 更多关于Laravel相关内容感兴趣的读者可查看本站专题
领取专属 10元无门槛券
手把手带您无忧上云