首页
学习
活动
专区
圈层
工具
发布

PHP-Laravel(DB类操作数据库)

四、DB类操作数据库(重点) 按照MVC 的架构,对数据的操作应该放在 Model 中完成,但如果不使用Model,我们也可以用 laravel框架提供的 DB 类操作数据库。...(2)数据库在laravel框架中的配置 在.env文件里面, ? 也可以在config目录下面的database.php文件里面配置。...①Update方法表示可以修改整个记录中的全部字段; ②Increment和decrement表示修改数字字段的数值(递增或者递减),典型的应用:记录登录次数、积分的增加; 案例:把id=1的名称,改名为...:从什么地方开始 组合起来等价于limit 5,5 5、删除数据(delete)【了解】 在删除中,有两种方式:物理删除(本质就是删除)、逻辑删除(本质是修改) 数据删除可以通过delete函数和truncate...函数实现, delete表示删除记录; truncate表示清空整个数据表; DB::table(‘table_name’)->where(‘id’,‘1’)->delete(); 例如:删除id小于3

4.5K20

通过 Laravel 查询构建器实现简单的增删改查操作

通过前面几篇教程的预热,我们已经连接上数据库,创建好了数据表,填充好了数据,接下来,就是在 Laravel 应用中实现对数据库的增删改查了。...原生删除语句 要删除数据表记录,可以通过 DB 门面的 delete 方法实现: $id = 8; $affectedRows = DB::delete('delete from `users` where...上述代码返回的也是包含指定查询结果的 stdClass 集合: 有时候我们可能希望返回查询结果中的第一条记录,这可以通过将 get 方法替换为 first 方法来实现: $user = DB::table...更新记录 更新数据库记录通过 update 方法来完成,我们可以在该方法中传入待修改字段及对应修改值数组: $id = 11; $affectedRows = DB::table('users')->where...delete(); 同样,我们通过 where 方法指定删除 id >= 11 的记录,delete 方法返回受影响行数,具体逻辑和原生删除语句也是一样的。

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

    3分钟短文:Laravel查询构造器,告别手写SQL的艰苦岁月

    ,['valie', $id]); 和按照条件删除条目: $countDeleted = DB::delete('delete from contacts where archived = ?'...,[true]); 为了编程愉悦感,还是回归我们的laravel推荐的链式操作的方式来演示更多更复杂的功能。...Carbon::now()->subDay())->get(); 复杂的查询莫过于使用多表联合查询,使用子查询,使用比较绕的or查询,我们对or查询举两个例子, 大家在调试的时候,一定要对自己写的代码打印一下最终生成的...(); 这一条要求要么vip是true,要么created_at字段在一天以内。...写在最后 本文轻描淡写地讲解了laravel中的查询构造器,讲了一个比较复杂的OR查询,因为使用闭包组装WHERE约束条件,所以会有些难以理解, 不过对比打印生成的SQL语句后,大家应该会豁然开朗!

    1.7K10

    3分钟短文:Laravel查询构造器,告别手写SQL的艰苦岁月

    ,['valie', $id]); 和按照条件删除条目: $countDeleted = DB::delete('delete from contacts where archived = ?'...,[true]); 为了编程愉悦感,还是回归我们的laravel推荐的链式操作的方式来演示更多更复杂的功能。...Carbon::now()->subDay())->get(); 复杂的查询莫过于使用多表联合查询,使用子查询,使用比较绕的or查询,我们对or查询举两个例子, 大家在调试的时候,一定要对自己写的代码打印一下最终生成的...(); 这一条要求要么vip是true,要么created_at字段在一天以内。...写在最后 本文轻描淡写地讲解了laravel中的查询构造器,讲了一个比较复杂的OR查询,因为使用闭包组装WHERE约束条件,所以会有些难以理解, 不过对比打印生成的SQL语句后,大家应该会豁然开朗!

    2.2K11

    通过 Laravel 创建一个 Vue 单页面应用(五)

    组件,在Update按钮下新增一个Delete按钮的方式,向 /users/:id/edit 视图组件中添加删除功能。... 我们从Update按钮中复制 :disabled 属性到Delete按钮中,从而防止我们在执行某个操作时,导致意外的更新或者删除。...(response); }); } 我们在 API 客户端调用 delete() 方法 ,然后绑定一个回调函数来注销控制台中的响应对象。...如何对成功删除用户作出相应的反馈 与更新一个用户不同的一点是,一旦我们成功删除了一个用户记录,那么数据库中就没有这个用户的记录了。在传统的网页应用中,我们会删除那条用户记录,然后重定向返回用户列表。...你也可以使用诸如 portal-vue 之类的插件或者布局中的一个组件来临时闪烁消息(或者在消息弹出后,使用强制关闭按钮关闭),显示一个操作是否已经成功(或者失败),从而向用户提供反馈。

    6K20

    【Laravel系列4.2】查询构造器

    另外,像上面测试代码中我们是一条一条地插入数据的,也可以整个批量地插入数据,后面我们会讲到。...delete() 方法用于删除数据,它可以直接指定一个数据的主键 ID ,同时它也可以使用 where() 条件的方式删除,大家可以自己尝试一下。...我们又发现了一个设计模式在 Laravel 框架中的应用,意外不意外,惊喜不惊喜! 连表查询 普通的连表查询的使用还是非常简单的,我也就不多说了,下面的代码中也有演示。...(比如记录插入前最后一条的 ID 值然后再查询一次大于这个 ID 的所有数据的 ID 值) Route::get('db/test/batch/insert', function () { $data...这个方法中的每个方法里面都是在拼接我们需要的这条 update 更新语句。

    18.8K10

    【Laravel系列4.1】连接数据库与原生查询

    我们还能看到许多其它数据库的配置,不过,今天我们的重点还是在 mysql 这个配置中。...从 options 这个参数里面,我们可以看出,Laravel 默认使用的是 PDO 连接的数据库,我也没有研究在 Laravel 中如何使用 mysqli 进行连接,因为 PDO 确实已经是事实的连库标准了...echo '删除成功'; }); 代码很简单,就不多做解释了,不过这里大家能看到的一点是,我们在修改和删除操作中,绑定数据使用的是 :xxx 这种方式哦!...'=>$id]); echo '删除成功'; }); 嗯,你猜对了,我们的执行成功了,使用 insert() 方法,但是里面的语句是一条 delete 语句,是可以执行成功的。...在 laravel/framework/src/Illuminate/Database/Connection.php 文件中,我们可以找到 insert() 、update()、delete() 这些方法

    4.8K50

    3分钟短文:Laravel说要用软删除,可不要真删

    真实的SQL如下: DELETE FROM events WHERE id = 12; laravel提供了许多语法糖,上面使用 find 和 delete 两个步骤,可以缩减为一个方法 destroy...软删除 在许多情况下,你不会真正想要从数据库中删除记录,而是用一种不再在应用程序中显示它们的方式对其进行注释。这就是所谓的软删除。...Laravel本身支持软删除,只需要进行少量的配置更改,以确保在执行delete或destroy时,模型的记录不会被实际删除。作为一个例子,我们修改Event模型以支持软删除。...任何设置deleted_at为日期时间值的记录,都不会包含在任何查询结果中,因此看起来已经被删除了。...如果你在代码内要坚持查询全量数据,也包含软删除了的数据,那么代码这样写: $events = Event::withTrashed()->get(); 写在最后 本文我们有重温了laravel的模型软删除功能

    2.9K00

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

    虽然在表单中设置了 user_id,但是并没有应用批量赋值。 软删除 我们在日常开发过程中,删除数据库记录在所难免,但是我们多数时候并不想从数据库中物理删除记录,而只是想从业务角度逻辑删除。...实现原理 Eloquent 模型类为我们提供了「软删除」功能的支持。这就意味着,在 Laravel 中,我们不需要编写任何额外代码就可以实现对数据库记录的「软删除」。...要软删除一条记录,在对应模型类实例上调用 delete 方法即可,底层会自动将数据表的 deleted_at 字段设置为当前时间,表示该记录已经被「删除」。...相关方法 要判断一条记录是否被软删除,可以通过 trashed 方法: $post = Post::findOrFail(32); $post->delete(); if ($post->trashed...在某些场景下,你可能只需要获取被软删除的记录,这可以通过 onlyTrashed 方法来实现: $post = Post::onlyTrashed()->where('views', 0)->get()

    3.2K10

    30分钟用Laravel实现一个博客

    在学习过程中,你只需要操作一次数据库,不需要自己构建html视图模板(当然还是要写一些html和js代码的),不需要考虑外部的css、js。...2、使用 composer 创建项目。 3、配置 laravel 的环境 ./env 。然后使用 composer 安装了汉化包,并且在 /config/app.php 中设置时区并且让中文包生效。...}}"> @csrf {{-- 这里伪造DELETE请求 --}} @method("DELETE") “删除文章” 按钮其实是调用了一个 js 函数,我们在...以删除举例 $blog->delete(); session()->flash('success', '删除文章成功!')...第三阶段总结 我们使用命令创建了一个 “资源控制器” 我们在 /routes/web.php 定义了一条资源路由 我们使用 BlogController 中的7个方法完成了对 博客文章 的 CURD(增删改查

    9.4K00

    Laravel 表单方法伪造与 CSRF 攻击防护

    GET:请求指定的页面信息,并返回响应实体。一般来说 GET 方法应该只用于数据的读取,而不应当用于会产生副作用的非幂等的操作中。...DELETE 请求后指定资源会被删除,DELETE 方法也是幂等的。 TRACE:请求服务器回显其收到的请求信息,该方法主要用于 HTTP 请求的测试或诊断。...表单请求方法伪造 要告知 Laravel 当前提交的表单使用的是 GET/POST 之外的其他请求方式,需要在表单中添加一个名为 _method 的隐藏字段,字段值是「PUT」、「DELETE」或 「PATCH...2、CSRF 保护 在开始之前让我们来实现上述表单访问伪造的完整示例,为简单起见,我们在路由闭包中实现所有业务代码: Route::get('task/{id}/delete', function ($...在 Laravel 中,和表单方法伪造一样,支持通过 HTML 表单隐藏字段传递这个值: Route::get('task/{id}/delete', function ($id) { return

    11.1K40

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

    对于 Laravel 中标准的 Eloquent 模型类来说,每个表都应该有两个字段,一个是 updated_at ,另一个是 created_at ,分别是两个时间戳字段,用于记录数据的创建时间和修改时间...等等,不对呀,我们在模型里面定义的是一个 gender() 方法,怎么在外面使用的是一个属性?别急,我们再来看看源码,看看框架中是如何把调用属性变成调用一个方法的。...在这个类中,你会发现有不少魔术方法的使用,比如 __get() 这个方法。...这里我也不多做讲解了,反正如果是在对象调用的时候,调用的是没有明确在类模板中写下的属性,就会来到这个 __get() 魔术方法中。...当然,这只是最简单的一种一对一的关联,Laravel 框架中还可以实现非常复杂的关联,包括一对多,多对一,多对多的关联,这些内容还是大家自己研究怎么使用吧,毕竟我们文章的主旨还是在于搞清楚它们是怎么运行的

    11.3K20

    3分钟短文 | Laravel模型关联删除表记录,用观察者还是事件钩子

    当删除该用户时,想要同时删除关联的photo表的相关记录。应该用什么办法呢? ? 本文就来说说 Laravel ORM 操作中的事件钩子。...$this->photo()->delete(); 如果程序中每个地方逻辑上进行了删除操作,岂不是都要手动这么重复写,这些重复代码真的是无用功。...那么Laravel中是怎么写的呢,如何自动在触发了 user 的删除时间,自动进行 photo 的删除操作?我们可以借助于 Eloquent ORM 提供的 deleting 事件,做删除动作。...这样在删除动作上只用维护一处代码,程序内所有的 delete 事件都会自动触发该动作,复用率大大地提升了。 再进一步 实现同样的需求,往往有很多种方式。...不推荐使用! 写在最后 本文通过3种方式,实现了Laravel中关联删除表记录的功能。

    2.3K10

    为什么 Laravel 这么优秀?

    会自动帮我们注册 5 条路由如下所示,包括用于新增操作的 POST 请求,用于删除的 DELETE 请求等: file Laravel 路由虽然是非常优秀的设计,但它却不是最高效的设计。...# 更新&选择&删除# 接下来我们来看如何在 Laravel 中实现查询/删除/更新操作,这部分的记录你可以参考下面这几个 Commit: - feat: create course and related...put($key, $value, $seconds); } 在使用 Cache 时,我们基本不用关心到底用的是文件缓存还是 Redis 缓存;在使用队列时也不用关心用的是 sync 队列还是专业的...container 中设置不同的值;如 CacheServiceProvider 会向容器中注册 Cache 对象,后续在使用 Cache::get 时就使用的是这里注册的 Cache 对象,在注册阶段不应该向容器中获取值...Laravel 的绝大多数方法参数中,你可以随意的注入任意数量的参数;这也是我最喜欢的一点。

    5.7K10

    Laravel API教程:如何构建和测试RESTful API

    在本文中,我们将探讨如何构建和测试使用Laravel进行身份验证的强大API。我们将使用Laravel 5.4,所有的代码都可以在GitHub上参考。...我们将使用HTTP动词的语义: GET:检索资源 POST:创建资源 PUT:更新资源 DELETE:删除资源 ?...该文章应该有一个标题和一个正文字段,以及创建日期。Laravel通过Artisan-Laravel的命令行工具提供了几个命令,可以通过生成文件并将其放在正确的文件夹中来帮助我们。...注销 使用我们当前的策略,如果令牌错误或丢失,用户应该收到未经身份验证的响应(我们将在下一节中实现)。因此,对于一个简单的注销端点,我们将发送令牌,它将在数据库上删除。....'], 200); } 使用此策略,用户拥有的任何令牌都将无效,API将拒绝访问(使用中间件,如下一节所述)。这需要与前端进行协调,以避免用户在没有访问任何内容的情况下保持记录。

    24.3K20

    Laravel 5 系列入门教程(二)【最适合中国人的 Laravel 教程】

    我们将改变学习路线,不再像 Laravel 4 教程那样先构建登录系统。在本篇教程中,我们将一起构建 Pages 的管理功能,尝试 Laravel 的路由和 PHP 的命名空间。 1....路由 Laravel 中的路由,跟其他 PHP 框架一样,作用是把各种请求分流到各个控制器。...而是 http://fuck.io:88/admin ,如果这段代码是 `Route::get('fuck'` 的话,那么 URL 就应该是 http://fuck.io:88/admin/fuck...Laravel 5 把命名空间全部隔开,控制器在 `\App\Http\Controllers`,模型在 `\App`,让我们在刚上手的时候就体验命名空间分离的感觉,总体上其实是会降低学习成本的。...页面上的新增、编辑、删除的功能均已经完成,并且加入了表单验证,Pages 管理功能完成!

    1.3K40

    通过 Laravel Eloquent 模型实现简单增删改查操作

    属性为模型类指定使用哪个连接: protected $connection = 'connection_name'; 查询数据 日常开发中,大部分操作都是数据库中查询数据,Eloquent 模型了为我们提供了很多方法帮助我们从数据库中获取数据...$post->views); } } }); 除此之外,在 Eloquent 模型中还可以通过 cursor 方法每次只获取一条查询结果,从而最大限度减少内存消耗: foreach...如果你想要在单条记录返回结果为空时返回 404 响应(在控制器方法中可能需要用到类似操作),可以通过 firstOrFail 或者 findOrFail 方法在找不到对应记录时抛出 404 异常,从而简化代码编写...执行上面的代码就会在数据库新增一条记录(我们在 Tinker 中执行上述代码): ? 我们先要创建一个新的 Post 模型实例,然后依次设置需要设置的字段,最后调用 save 方法保存即可。...,删除对应记录更简单,获取到模型实例后,直接调用其删除方法即可: $post = Post::find(31); $post->delete(); 这样,就完成了 id = 31 对应数据表记录的删除

    9.4K20
    领券