前言
大家都知道,现在的开发测试都是讲究多人团队协作完成,每个人都有本地环境,在以前我们一般是手动的添加数据,比如在数据库查询器中使用sql语句进行数据插入。如果数据较少,那还是蛮轻松的,但是如果数据过大,那就很蛋疼了,但是这在Laravel中就很轻松,可以使用数据迁移。
本文就详细的介绍了关于Laravel中migrate使用的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:
生成迁移
命令:
Migration
php artisan make:migration create_users_table
意思:创建一个迁移,其实就是创建一张名为users的表。
接着你便能在database/migrations这个目录下找到与2014_10_12_000000_create_users_table.php这个类似的文件。
和以前用php语句创建表一样,我们可以在2014_10_12_000000_create_users_table.php这个文件中写上我们要创建表的字段及约束条件。
–table和–create选项可以用于指定表名以及该迁移是否要创建一个新的数据表。这些选项只需要简单放在上述迁移命令后面并指定表名,如果你想要指定生成迁移的自定义输出路径,在执行make:migration命令时可以使用–path选项,提供的路径应该是相对于应用根目录的。
迁移结构
一个migration类包含两个方法up和down。
up中主要包含创建表的具体内容。
down中和前者相反。
Schema::create接受两个参数。第一个是你要创建表的表名;第二个是一个闭包(匿名函数),获取用于定义新表的 Blueprint 对象。
Migration
<?php use Illuminate\Support\Facades\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration; class CreateUsersTable extends Migration { /** * Run the migrations. * * @return void */ public function up() { Schema::create('users', function (Blueprint $table) { $table->increments('id'); $table->string('name'); $table->string('email')->unique(); $table->string('password'); $table->rememberToken(); $table->timestamps(); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::dropIfExists('users'); } }
运行迁移
要运行应用中所有未执行的迁移,可以使用 Artisan 命令的migrate方法。
Migration
php artisan migrate
回滚迁移
想要回滚最新的一次迁移”操作“,可以使用rollback命令,注意这将会回滚最后一批运行的迁移,可能包含多个迁移文件:
Migration
php artisan migrate:rollback
migrate:reset命令将会回滚所有的应用迁移:
Migration
php artisan migrate:reset
在单个命令中回滚/迁移
migrate:refresh命令将会先回滚所有数据库迁移,然后运行migrate命令。这个命令可以有效的重建整个数据库:
Migration
php artisan migrate:refresh php artisan migrate:refresh --seed
常用迁移属性
$table->increments(‘id'); | 数据库主键自增 ID |
$table->integer(‘votes'); | 等同于数据库中的 INTEGER 类型 |
$table->float(‘amount'); | 等同于数据库中的 FLOAT 类型 |
$table->char(‘name', 4); | 等同于数据库中的 CHAR 类型 |
$table->dateTime(‘created_at'); | 等同于数据库中的 DATETIME 类型 |
$table->enum(‘choices', [‘foo','bar']); | 等同于数据库中的 ENUM 类型 |
$table->tinyInteger(‘numbers'); | 等同于数据库中的 TINYINT 类型 |
$table->timestamps(); | 添加 created_at 和 updated_at 列 |
一些列名约束条件的写法
Migration
Schema::table('users', function ($table) { $table->integer('votes')->unsigned(); //无符号类型 });
常用约束
->first() | 将该列置为表中第一个列 (仅适用于 MySQL) |
->after(‘column') | 将该列置于另一个列之后 (仅适用于 MySQL) |
->nullable() | 允许该列的值为 NULL |
->default($value) | 指定列的默认值 |
->unsigned() | 设置 integer 列为 UNSIGNED |
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对小牛知识库的支持。
本文向大家介绍Swift学习教程之SQLite的基础使用,包括了Swift学习教程之SQLite的基础使用的使用技巧和注意事项,需要的朋友参考一下 前言 在我们的日常开发中,经常会遇到用户断网或者网络较慢的情况,这样用户在一进入页面的时候会显示空白的页面,那么如何避免没网显示空白页面的尴尬呢?答案就是:先在网络好的时候缓存一部分数据,这样当下次网络情况不好的时候,至少用户可以先看到之前缓存的内容,
本文向大家介绍seajs学习教程之基础篇,包括了seajs学习教程之基础篇的使用技巧和注意事项,需要的朋友参考一下 介绍 众所周知前端开发模块化已经是大势所趋,目前模块化的规范有很多,众所周知的有commonJS,Module/Wrappings和AMD等,而且ES6也着手开始制定模块化机制的实现。类似于c/c++的include,java中的import关键字,在js中也定义了require关键
本文向大家介绍Three.js基础学习教程,包括了Three.js基础学习教程的使用技巧和注意事项,需要的朋友参考一下 一、Three.js官网及使用Three.js必备的三个条件 1.Three.js 官网 https://threejs.org/ 2.使用Three.js必备的三个条件 (To actually be able to display anything with Three.js
本文向大家介绍Django学习笔记之ORM基础教程,包括了Django学习笔记之ORM基础教程的使用技巧和注意事项,需要的朋友参考一下 ORM简介 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术。 简单的说,ORM是通过使用描述对象和数据库之间映射的元数据,将程序中的对象自动持久化到关系数据
本文向大家介绍socket.io学习教程之基础介绍(一),包括了socket.io学习教程之基础介绍(一)的使用技巧和注意事项,需要的朋友参考一下 前言 Web端与服务器间的实时数据传输的是一个很重要的需求,但最早只能通过AJAX轮询询实现。在WebSocket标准没有推出之前,AJAX轮询是唯一可行的方式(通过Flash浏览器也可以,但这里不做讨论)。AJAX轮询原理是设置定时器,定时通过AJA
本文向大家介绍Lua基础教程之表(Table)学习笔记,包括了Lua基础教程之表(Table)学习笔记的使用技巧和注意事项,需要的朋友参考一下 表 定义表(Table)的方式:a = {}, b = {…} 访问表的成员:通过“.”或者“[]”运算符来访问表的成员。注意:表达式a.b等价于a[“b”],但不等价于a[b] 表项的键和值:任何类型的变量,除了nil,都可以做为表项的键。从简单的数值、