Laravel结构生成器
简介
Laravel 的 Schema 类提供了一种与数据库无关的方式维护表。它和 Laravel 所支持的所有数据库都能很好的工作,并且提供了统一的接口。
创建和删除表
使用 Schema::create 创建一个数据库的表:
Schema::create('users', function($table)
{
$table->increments('id');
});
传递给 create 函数的第一个参数是表的名字,第二个参数是一个闭包,将接受一个 Blueprint 对象用于定义新的表。
使用 rename 函数重命名一个已存在的表:
Schema::rename($from, $to);
使用 Schema::connection 函数指定结构操作所使用的数据库连接:
Schema::connection('foo')->create('users', function($table)
{
$table->increments('id');
});
使用 Schema::drop 函数删除一个表:
Schema::drop('users');
Schema::dropIfExists('users');
添加字段
使用 Schema::table 函数更新一个已存在的表:
Schema::table('users', function($table)
{
$table->string('email');
});
表生成器包含一系列的字段类型用于构建表:
| 命令 | 描述 |
|---|---|
$table->bigIncrements('id'); |
Incrementing ID using a "big integer" equivalent. |
$table->bigInteger('votes'); |
BIGINT equivalent to the table |
$table->binary('data'); |
BLOB equivalent to the table |
$table->boolean('confirmed'); |
BOOLEAN equivalent to the table |
$table->date('created_at'); |
DATE equivalent to the table |
$table->dateTime('created_at'); |
DATETIME equivalent to the table |
$table->decimal('amount', 5, 2); |
DECIMAL equivalent with a precision and scale |
$table->double('column', 15, 8); |
DOUBLE equivalent with precision |
$table->enum('choices', array('foo', 'bar')); |
ENUM equivalent to the table |
$table->float('amount'); |
FLOAT equivalent to the table |
$table->increments('id'); |
Incrementing ID to the table (primary key). |
$table->integer('votes'); |
INTEGER equivalent to the table |
$table->longText('description'); |
LONGTEXT equivalent to the table |
$table->mediumText('description'); |
MEDIUMTEXT equivalent to the table |
$table->morphs('taggable'); |
Adds INTEGER taggable_id and STRING taggable_type |
$table->smallInteger('votes'); |
SMALLINT equivalent to the table |
$table->softDeletes(); |
Adds deleted_at column for soft deletes |
$table->string('email'); |
VARCHAR equivalent column |
$table->string('name', 100); |
VARCHAR equivalent with a length |
$table->text('description'); |
TEXT equivalent to the table |
$table->time('sunrise'); |
TIME equivalent to the table |
$table->timestamp('added_on'); |
TIMESTAMP equivalent to the table |
$table->timestamps(); |
Adds created_at and updated_at columns |
->nullable() |
Designate that the column allows NULL values |
->default($value) |
Declare a default value for a column |
->unsigned() |
Set INTEGER to UNSIGNED |
如果你使用 MySQL 数据库,您可以使用 after 函数指明字段的顺序:
在 MySQL 中使用 After
$table->string('name')->after('email');
重命名字段
使用 renameColumn 函数重命名一个字段:
重命名一个字段
Schema::table('users', function($table)
{
$table->renameColumn('from', 'to');
});
注意: 不支持重命名
enum字段类型.
删除字段
从表中删除一个字段
Schema::table('users', function($table)
{
$table->dropColumn('votes');
});
从表中删除多个字段
Schema::table('users', function($table)
{
$table->dropColumn('votes', 'avatar', 'location');
});
检查存在性
您可以使用 hasTable 和 hasColumn 检查一个表或一个字段是否存在:
检查表是否存在
if (Schema::hasTable('users'))
{
//
}
检查字段是否存在
if (Schema::hasColumn('users', 'email'))
{
//
}
添加索引
结构生成器支持多种类型的索引,有两种方法可以添加它们。首先,您可以在字段定义后链式的定义它们,或者独立的添加它们:
链式创建一个字段和索引
$table->string('email')->unique();
或者,您可以选择在不同的行添加索引。下面是全部支持的索引类型:
| 命令 | 描述 |
|---|---|
$table->primary('id'); |
添加一个主键 |
$table->primary(array('first', 'last')); |
添加组合键 |
$table->unique('email'); |
添加唯一键 |
$table->index('state'); |
添加一个索引 |
外键
Laravel 也支持向表中添加外键约束:
向表中添加外键
$table->foreign('user_id')->references('id')->on('users');
在这个例子中,我们指明 user_id 字段参照 users 表中的 id 字段。
您也可以指明 "on delete" 以及 "on update" 行为选项:
$table->foreign('user_id')
->references('id')->on('users')
->onDelete('cascade');
可以使用 dropForeign 函数删除一个外键。像其他索引一样,一个相似的命名惯例被使用于外键的命名:
$table->dropForeign('posts_user_id_foreign');
注意: 当创建一个参照递增整数类型的外键的时候,记得把外键字段的类型定义为无符号。
删除索引
为了删除索引,必须指明索引的名字。Laravel 默认为索引分配了一个合理的名字。通过连接表明、索引的字段名以及索引类型的形式。这里是一些例子:
| 命令 | 描述 |
|---|---|
$table->dropPrimary('users_id_primary'); |
从 "users" 表中删除一个主键 |
$table->dropUnique('users_email_unique'); |
从 "users" 表中删除一个唯一键 |
$table->dropIndex('geo_state_index'); |
从 "geo" 表中删除一个索引 |
存储引擎
通过在结构生成器设置 engine 属性为表设置存储引擎:
Schema::create('users', function($table)
{
$table->engine = 'InnoDB';
$table->string('email');
});
Laravel结构生成器的更多相关文章
- Laravel学习笔记(五)数据库 数据库迁移案例2——创建数据结构,数据表,修改数据结构
默认假设 所有的列在定义的时候都有默认的假设,你可以根据需要重写. Laravel假定每个表都有一个数值型的主键(通常命名为”id”),确保新加入的每一行都是唯一的.Laravel只有在每个表都有数值 ...
- php框架laravel:数据库建立:artisan
aravel 迁移是一种数据库的版本控制.迁移通常和 结构生成器 配对使用来管理您应用程序的数据库结构. 配置数据库 我们安装wamp,并且使用mysql方式.用wamp自带的phpMyAdmin添加 ...
- 使用laravel 的artisan快速创建表
参考:使用laravel 的artisan快速创建表 字段类型参考链接: 结构生成器 版本: Laravel 4.2 1. 创建migrate 文件 php artisan migrate:make ...
- [转]Laravel 4之数据库操作
Laravel 4之数据库操作 http://dingjiannan.com/2013/laravel-database/ 数据库配置 Laravel数据库配置在app/config/database ...
- Laravel 5.2 教程 - 迁移
一.简介 迁移(Migrations)是一种数据库的版本控制.可以让团队在修改数据库结构的同时,保持彼此的进度一致.迁移通常会和 结构生成器 一起使用,可以简单的管理数据库结构. 下面以创建学生表的迁 ...
- laravel中migration 数据迁移
简介 数据库迁移就像是数据库的版本控制,可以让你的团队轻松修改并共享应用程序的数据库结构.迁移通常与 Laravel 的数据库结构生成器配合使用,让你轻松地构建数据库结构.如果你曾经试过让同事手动在数 ...
- Laravel - 基础
1.使用 composer 创建项目 composer create-project --prefer-dist laravel/laravel blog 报错1 [ErrorException]pr ...
- Laravel学习笔记(三)数据库 数据库迁移
该章节内容翻译自<Database Migration using Laravel>,一切版权为原作者. 原作者:Stable Host, LLC 翻译作者:Bowen Huang 正文: ...
- .net转php laraval框架学习系列(二)项目实战---Models
上一篇已经介绍开发环境的搭建,如果有问题可以在文章后留言. 这篇将从项目实战开发,一步一步了解laravel框架. 在开发mvc项目时,models都是第一步. 下面就从建模开始. 实体关系图 由于不 ...
随机推荐
- 微信小程序滚动条设置
隐藏滚动条 ::-webkit-scrollbar { width: 0rpx; height: 0rpx; background-color: transparent; } 其实设置为宽高为 0 或 ...
- Java基础自学小项目
实现一个基于文本界面的<家庭记账软件> 需求:能够记录家庭的收入,支出,并能够收支明细表 主要涉及一下知识点: - 局部变量和基本数据类型 - 循环语句 - 分支语句 - 方法调用和返回值 ...
- Kubernetes-2.组件
内容主要摘自官网文档资料 官网地址 本文概述了交付正常运行的Kubernetes集群所需的各种组件. 本文编写基于kubernetes v1.17版本 目录 Kubernetes集群 Master组件 ...
- 后端程序员之路 21、一个cgi的c++封装
在"3.fastcgi.fastcgi++"中,我们了解了cgi,也尝试了fastcgi++,这里,再记录一种对fastcgi的封装. 1.cgi接口层 request_t ...
- mysql添加远程连接权限
查看登录用户 mysql> select host,user,password from user; 想用本地IP登录,那么可以将以上的Host值改为自己的Ip即可. 这里有多个root,对应着 ...
- python flask框架详解
Flask是一个Python编写的Web 微框架,让我们可以使用Python语言快速实现一个网站或Web服务.本文参考自Flask官方文档, 英文不好的同学也可以参考中文文档 1.安装flask pi ...
- 2020年HTML5考试模拟题整理(二)
1.以下是HTML5新增的标签是: AA.<aside>B.<isindex> C. <samp>D.<s>2.以下不是HTML5的新增的标签是: BA ...
- SQL SERVER跨数据库服务,联表进行查询
SELECT * FROM 数据库A..表A a, 数据库B..表B b WHERE a.field=b.field
- RabbitMQ镜像队列集群搭建、与SpringBoot整合
镜像模式 集群模式非常经典的就是Mirror镜像模式,保证100%数据不丢失,在实际工作中也是用的最多的,并且实现集群比较的简单. Mirror镜像队列,目的是为了保证 RabbitMQ 数据的高可靠 ...
- P2516 [HAOI2010]最长公共子序列 题解(LCS)
题目链接 最长公共子序列 解题思路 第一思路: 1.用\(length[i][j]\)表示\(a\)串的前\(i\)个字符与\(b\)串的前\(j\)个字符重叠的最长子串长度 2.用\(num[i][ ...