Laravel 7 开始新增了一些新特性,今天我们来讲解下 路由绑定的新用法,自定义键名(slug)以及作用域(范围限定) 首先我们 安装最新版本的 Laravel ,并且创建两张数据表。.../ui npm install && npm run dev 我们使用内置服务,来启动一个 web server php artisan serve 生成用户填充数据 首先修改 .env 文件。...::class); $this->call(PostSeeder::class); } } 运行迁移文件,进行数据填充 php artisan db:seed ok,以上准备工作做完...当然我们在以前的版本可以更改这个,我们需要在 模型中重写一个方法 getRouteKeyName 接下来我们看下 Laravel 7 以前是怎么实现的 首先。...其实如果我们要实现如上的模式,我们还得需要设置模型的绑定关系 Post 模型 <?
在 Laravel 框架中,如果想要快速填充测试数据到数据库,可以借助框架提供的填充器功能,通过填充器,我们可以非常方便地为不同数据表快速填充测试数据。...为入口类,调用该类的 run 方法,你可以将所有对其他填充器的调用定义在该方法中,例如: $this->call(UsersTableSeeder::class); 这样,就可以一次性调用所有填充器啦...DatabaseSeeder 类的 run 方法中运行这个填充器类: public function run() { $this->call(UsersTableSeeder::class);...现在,我们先抛开测试不谈,赶紧来看下如何在 Laravel 中定义模型工厂。...,Faker 类库提供了丰富的字段规则帮助我们生成伪造字段值,这些规则可以在官方文档中查看,这里,我们使用 调用模型工厂 在调用这些模型工厂的时候,需要借助 Laravel 提供的全局辅助函数 factory
一、Migration创建数据表与Seeder数据库填充数据 数据库迁移就像是数据库的版本控制,可以让你的团队轻松修改并共享应用程序的数据库结构 1.1 创建迁移 php artisan make:...up 方法可为数据库添加新的数据表、字段或索引,而 down 方法则是 up 方法的逆操作。可以在这两个方法中使用 Laravel 数据库结构生成器来创建以及修改数据表。...1.5.3 调用其他 Seeders 在 DatabaseSeeder 类中,你可以使用 call 方法来运行其他的 seed 类。 /** * Run the database seeds...你也可以使用 migrate:refresh 命令来填充数据库,该命令会回滚并重新运行所有迁移。...5.5 基础 Laravel 中文文档:Laravel 的数据库迁移 Migrations
数据填充 使用 DB 插入数据的方式学会后我们就可以讲点填充了,以前下载开源项目如果没有给出安装步骤,哪一般都先找 sql 文件,但是 sql 文件中一般不只是表结构一般还有一些初始化的数据昨天学习了表结构今天来玩玩数据...,刚刚学习了插入数据的方式,但那是在控制器里的这种创建路由创建控制器写填充的方式不太优雅,laravel 是优雅的框架这么做跟 laravel 的优雅不符,所有 laravel 必定准备了其他方法,下面学下的填充就是向数据库批量添加数据的...,简单概述下就是 数据库迁移+数据填充 = SQL 我们先来看看官网的介绍 Laravel 包含一个填充类可以为你的数据库填充测试数据,所有的填充类都放在 database/seeds 目录下。...通过这个类,你可以用 call 方法来运行其它的 seed 类从而控制数据填充的顺序。...这个命令可以用来重建数据库 php artisan migrate:refresh --seed 另外在生产环境中强制使用一些填充操作可能会导致原有数据的更新或丢失。
创建一个真正的用户端点 我们将创建一个 UsersController 使用 Laravel 5.5 新的 API 资源 来返回 JSON 数据。...在创建控制器和 API 资源之前, 让我们首先设置一个数据库并且进行数据填充,以便为我们的 SPA 提供一些测试数据。...Laravel附带了一个Users表的迁移,我们使用它来填充数据: # 确保数据库seeders自动加载 composer dump-autoload php artisan migrate:fresh...UsersIndex.vue 组件后显示出的 SPA 结果: 下一步是什么 我们现在有一个有效的 API,可以从数据库中获取真实数据,还有一个简单的分页组件,该组件在后端使用 Laravel 的 API...模型资源进行简单的分页链接并将数据包装在 数据 键中。
的方式去删除索引中的数据。...二、Delete By Query API 介绍 怎么理解这个API呢?实际是批量删除数据的意思 功能:根据特定的查询条件对ES相关索引中某些特定的文档进行批量删除。...相反,在被查询到的文档标记删除过程同样需要占用磁盘空间,这个时候,你会发现触发该API操作的时候磁盘不但没有被释放,反而磁盘使用率上升了。...使用Delete By Query 删除API注意事项: 1, 一般生产环境中,使用该API操作的索引都很大,文档都是千万甚至数亿级别。...max_num_segments=1 上面API的意思表示合并索引中的每个分片为一个单独的段,可以先设置大一点,10-5-1,一点一点慢慢降到1。一般推荐为1.
免责声明: 我只是查看了完整的基于 Laravel 5.3+ 的 Laravel 项目(不包括依赖包) 1....我还注意到 Laravel.io 已经升级到了 Laravel 5.4, 但是测试套件仍然使用的是5.3的风格, 使用 BrowserKitTestCase implementation。...这是 Miguel Piedrafita 的一个非常简单的项目,Orgmanager 的测试也是非常简单易懂的。还分为单元,功能和 API 测试。 ? ...,之后是一个个列举更多的测试: 仓库中的官方统计数据看起来非常好: 89% 的测试覆盖率。 ...迁移到较新版本的 Laravel 可能很痛苦 —— 例如,5.3 版本的测试看上去和 5.4 版本不一样。所以你需要提前考虑更新。
什么是Swoole 直接套用Swoole官网的介绍:PHP的异步、并行、高性能网络通信引擎,使用纯C语言编写,提供了PHP语言的异步多线程服务器,异步TCP/UDP网络客户端,异步MySQL,异步Redis...,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询。...如果你Swoole业务代码是写在一个叫server.php的文件中,那么在命令行下输入php server.php开启。...强烈推荐在你的laravel项目中,使用 laravel-s 这个包. composer require "hhxsv5/laravel-s:~1.0" -vvv 然后,依赖 kuaiapp/db 这个包...start 现在你就可以测试你的数据库查询了。
说明:本文主要聊一聊Laravel测试数据填充器Seeder的小技巧,同时介绍下Laravel开发插件三件套,这三个插件挺好用哦。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...开发环境:Laravel5.2 + MAMP + PHP7 + MySQL5.5 开发插件三件套 在先聊测试数据填充器seeder之前,先装上开发插件三件套,开发神器。先不管这能干些啥,装上再说。...,表的关系如下: Seeder填充测试数据 好,在聊到seeder测试数据填充之前,看下开发插件三件套能干些啥,下文中命令可在项目根目录输入php artisan指令列表中查看。...Laravel官方推荐使用模型工厂自动生成测试数据,推荐这么写的: //先输入指令生成database/seeds/CategoryTableSeeder.php文件: php artisan make...先在DatabaseSeeder.php文件中填上这次要填充的Seeder: public function run() { // $this->call(UsersTableSeeder
本文内容主要围绕在 Laravel 5.5 中使用 API 开发的重要步骤,着重介绍如何利用 Laravel 的 API 资源(Resource)和控制器(Controller)进行多因素身份验证(MFA...注:本文受到Laravel创始人Taylor Otwell介绍使用 Laravel5.5 开发API时如何替换 Fractal 的启发。 1....这些步骤旨在建立一个基本的 Laravel 5.5 项目,并做了一些初始化设置,包括创建模型、资源类和控制器,并配置使用 SQLite 作为数据库。 2....这是在开发或测试阶段常用的操作,可以使用 Laravel 的 Seeder 来填充数据库表,确保数据库中有一些初始数据可用于开发和测试。 3....简单来说,这意味着资源类中可以直接使用 $this->attributeName 的方式访问模型中的属性,而不必每次都通过模型实例去获取属性。
1、常见的使用方式(设置为null) 2、关于别的属性的介绍 CASCADE:这就是默认的选项,级联删除,你无需显性指定它。...PROTECT: 保护模式,如果采用该选项,删除的时候,会抛出ProtectedError错误。...SET_NULL: 置空模式,删除的时候,外键字段被设置为空,前提就是blank=True, null=True,定义该字段的时候,允许为空。...SET_DEFAULT: 置默认值,删除的时候,外键字段设置为默认值,所以定义外键的时候注意加上一个默认值。...SET(): 自定义一个值,该值当然只能是对应的实体了 3、补充说明:关于SET()的使用 **官方案例** def get_sentinel_user(): return get_user_model
引言 上一章我们了解了使用laravel迁移功能创建数据库表,把DBA的工作挪到开发端,这样把岗位都省出来了。 但是只有光秃秃的数据库表,有个壳子没有数据确实没啥用。...本文为大家讲讲laravel怎么给数据库造假数据,堂而皇之地假装生产。 本文使用的构建方式都是写脏数据,乱数据,无实质意义的数据,只对应用程序和数据库有用,别的嘛用没有!...类不类,方法不方法,函数不函数的!没错,就是一个代码片段,laravel约定的东西, 你这么写,在执行数据填充和测试的时候,它就起作用!就这么神奇。 那如何控制填充条数呢?...::class, 500)->create(); 怎么理解呢,就是我们创建了模型工厂类 ContactFactory,然后使用 factory 快捷函数进行实例化调用,并使用工厂类内的数据, 对每个模型发起...写在最后 本文介绍了使用laravel的Seeder进行数据填充,为了高效填充,我们介绍了工厂模式,这个高级玩意儿,确实用法有点偏,本不在五行八卦之列。希望大家用的开心。
文章正文 随着移动开发与JavaScript框架的兴起,使用RESTful API为数据与客户端之间构建单一接口成为最佳选择。 Laravel 是一个 专注提高开发人员生产力的php开发框架。...来源百度百科 资源(Resources) 资源将是actions的目标,在我们的文章和用户的情况下,他们有自己的端点: /articles /users 在这个laravel api教程中,资源将在我们的数据模型中具有...您可以将资源表示在多个数据模型中(或根本不在数据库中表示),并且模型完全不受用户限制。最后,您将以适合您的应用程序的方式来决定如何构建资源和模型。...您也可以使用该$guarded 属性,以允许除属性外的所有属性。 Database Seeding Database Seeding是使用我们可以用来测试数据库的虚拟数据填充我们的数据库的过程。...您可以使用许多外部工具来测试您的API; 然而,Laravel内部的测试是一个更好的选择 - 我们可以拥有测试API结构和结果的所有好处,同时保留对数据库的完全控制。
=laravel5 DB_USERNAME=root DB_PASSWORD=password 推荐新建一个名为 laravel5 的数据库,为了学习方便,推荐使用 root 账户直接操作。...模型 Models 接下来我们将接触Laravel最为强大的部分,Eloquent ORM,真正提高生产力的地方,借用库克的一句话:鹅妹子英!...这里需要强调一下,用命令行的方式创建文件,和自己手动创建文件没有任何区别,你也可以尝试自己创建这两个 Model 类。 Model 即为 MVC 中的 M,翻译为 模型,负责跟数据库交互。...$i, 'user_id' => 1, ]); } } } 然后修改同一级目录下的 `DatabaseSeeder.php`中: // $this->call(...'UserTableSeeder'); 这一句为 $this->call('PageTableSeeder'); 然后运行命令进行数据填充: composer dump-autoload php artisan
背景 最近,后台运维要求导出的 Excel文件,对于时间的筛选,能满足年份、月份的选择 通过了解,发现: 先前导出的文件,默认列数据都是字符串(文本)格式 同时,因为用的是 Laravel-excel...控件版本的问题,要实现的方式也不同 在此,根据版本不同,进行步骤整理,以便能帮助到有需要的小伙伴 … 所要达成的目标 框架 Laravel 版本: Laravel5.8 Excel...- Column formatting 参考文章:laravel-excel导出的时候写入的日期格式数据怎么在excel中正确显示成可以筛选的日期格式数据 提示 1..../** * @notes:获取导出的数据 * @return array 注意返回的数据为 Collection 集合形式 * @author: zhanghj...导出的时候写入的日期格式数据怎么在excel中正确显示成可以筛选的日期格式数据 Laravel Excel 3.1 导出表格详解(自定义sheet,合并单元格,设置样式,格式化列数据)
API经常公开其他开发人员可以在自己的应用程序中使用的数据,而不必担心数据库或编程语言的差异。 开发人员经常从API返回数据,该数据返回JSON格式的数据,并将其集成到前端应用程序中。...> 我们最终将使用API中的实时数据替换此硬编码值。...此代码使用v-for指令,它的作用类似于for-loop。 它遍历数据模型中的所有键 - 值对并显示每个数据的数据。...为了提出请求,我们将Vue中的mounted()函数与Axios库的GET函数结合使用来获取数据并将其存储在数据模型的results数组中。...保存该文件,然后打开vueApp.js并对其进行修改,以便向API发出请求并使用结果填充数据模型。
说明:本文主要学习PHP的回调类型callback type,通常在使用函数进行回调时,如使用call_user_func(callback, parameters)进行回调时,需要传入回调callback...,实际上有几种callback type的,在Laravel中也大量使用回调,并根据场景不同传入不同的回调类型。...开发环境:Laravel5.3 + PHP7 (Function/Static Class Method) Callback Type Function Callback Type是把函数名作为callable...Relation Class Method Callback Type是可以使用父类的方法传进去作为回调,形式如:([class_name, "parent::method_name"], public...中大量使用,比如Laravel的Pipeline源码就大量使用这种方式,Pipeline的源码可看:Laravel5.3Middleware源码解析。
说明:Laravel中经常使用PHP的Function Handling来设计代码,本文主要学习PHP的Function Handling特性,来提高写代码时的设计质量。...( ) func_num_args( ) function_exists( ) 开发环境:Laravel5.3 + PHP7 Function Handling call_user_func_array...在Laravel中大量使用这两个内置函数来设计代码,比如\Illuminate\Foundation\Application::fireAppCallbacks()的源码: /** * Call...Laravel中的IlluminateFoundationApplication::environment()使用了这三个函数来设计代码,很巧妙: /** * Get or check the...Handling,这个技术可以用来提高自己的代码设计能力,同时Laravel中也大量使用了这个技术来巧妙设计代码。
实际上,Laravel通过Schema Builder来设计数据库,通过Query Builder来CURD数据库。...Query Builder并不复杂或神秘,只是在PDO扩展的基础上又开放封闭的包装了一层,提供了fluent api,使得书写的代码也很简洁流畅。...开发环境: Laravel5.3 + PHP7 Folder/File Description Capsule Capsule文件夹下只有一个Manager类,主要实现了容器实例化,DatabaseManager...DatabaseManager对象,则实际上魔术调用DatabaseManager中的table()方法,看下__call()魔术方法源码: // $method = 'table', $parameters...($name); // 如果已经自定义了连接,如在AppServiceProvider的boot()中又使用DatabaseManager::extend()方法自定义了一个'mysql
领取专属 10元无门槛券
手把手带您无忧上云