数据库迁移创建表

本篇文章中使用的是mysql数据库,其他数据库需要修改env文件和app配置,请其他地方搜索一下就会找到。

创建示例

1.创建users表:

命令行键入

  1 php artisan make:migration create_users_table //users复数

  1 php artisan make:migration create_users_table --create=users//--create及对应的表名 users 

执行命令后,会在 /database/migrations/ 文件夹下生成对应的数据库迁移文件,通过修改文件里的up 方法和 down方法;

  • 当我们运行迁移时,up 方法会被调用。
  • 当我们回滚迁移时,down 方法会被调用。
  1   public function up()
2 {
3 Schema::create('users', function (Blueprint $table) {
4 $table->bigIncrements('id');
5 $table->string('name')->unique();
6 $table->string('email')->unique();
7 $table->timestamp('email_verified_at')->nullable();
8 $table->string('password');
9 $table->rememberToken();
10 $table->timestamps();
11 });
12 }

2.创建一个数据模型的时候 需要同时创建对应迁移文件可以加上 –m:

  1 php artisan make:model Models/Moment -m 

就在Models文件夹下创建了Moment数据模型 -m在 database/migrations创建了对应的数据库迁移文件。【注:类似的还有-f【工厂类】 –c【控制器】,可以合用-cfm,-cm等】

保存后执行

  1 php artisan migrate

会创建对应up方法中配置的字段的数据表。

【上面up方法中创建一个名为users的数据表,表包含id,name,email,email_verified_at,password,rememberToken[注:记住我选项被选中时生成],created_at,updated_at字段】

数据库迁移创建表

今后若想修改完善之前的已经创建好的数据表 不能再操作之前的数据库迁移文件。

修改 新增或删除字段需要创建一个新的数据库迁移文件:

操作前

请检查你的composer.json文件中已经添加好了doctrine/dbal依赖,Doctrine DBAL库是用来确定数据表中字段当前状态,及用于实现目标调整的SQL查询语句的创建工作的,安装依赖请在控制台中执行:

  1 composer require doctrine/dbal

安装完成后,接下来:

新增字段

在控制台中执行命令:

php artisan make:migration add_要添加的字段名_to_要添加字段的表名_table --table=要添加字段的表名

migrate的文件名称 上面那样写只是为了尽量规范而已,重要的是迁移文件里面的内容:

为示例向users表中添加一个post_id字段,所以我们的命令如下:

  1 php artisan make:migration add_post_id_to_users_table --table=users

然后会在database/migrations创建了对应的数据库迁移文件***_add_post_id_to_users_table.php:

  1 public function up()
2 {
3 Schema::table('users', function (Blueprint $table) {
4 $table->bigInteger('post_id')->nullable()->after('email');
5 });
6 }
7
8 public function down()
9 {
10 Schema::table('users', function (Blueprint $table) {
11 $table->dropColumn('post_id');
12 });
13 }

【注意方法里已经不是Schema::create方法的调用,而是Schema::table方法的调用了。】

然后,运行

  1  php artisan migrate

即可生效

修改原有字段属性

如果是修改,就调用change方法即可,比如想增加name 字段的字符串长度:

  1 Schema::table('users', function (Blueprint $table) {
2 $table->string('name', 50)->change();
3 });

比如将字段修改为可空:

  1 Schema::table('users', function (Blueprint $table) {
2 $table->string('name', 50)->nullable()->change();
3 });

然后,运行即可生效

修改字段名

  1 Schema::table('users', function (Blueprint $table) {
2 $table->renameColumn('from', 'to');//from字段改名为to字段
3 });

然后,运行即可生效

删除字段

如果目的是删除之前已经存在的表的某些字段,新建数据库迁移文件后,在该文件的up方法中键入如下代码;

  1 Schema::table('users', function (Blueprint $table) {
2 $table->dropColumn('votes');//删除users表的votes字段
3 });
4
5 Schema::table('users', function (Blueprint $table) {
6 $table->dropColumn(['votes', 'avatar', 'location']);//删除users表里面的votes,avatar,location这三个字段
7 });

然后,运行即可生效

Laravel 6.X 数据库迁移 创建表 与 修改表的更多相关文章

  1. Laravel5.5 数据库迁移:创建表与修改表

    数据库迁移是数据库的版本管理,要使用数据库迁移,需要在.env文件中连接好数据库(不多说).laravel本身已经存在user表和password_resets表的迁移了,因此,执行 php arti ...

  2. Laravel5.x的php artisan migrate数据库迁移创建操作报错SQLSTATE[42000]解决

    Laravel5.x运行迁移命令创建数据表:php artisan migrate报错. Illuminate\Database\QueryException  : SQLSTATE[42000]: ...

  3. Laravel 5.2数据库--迁移migration

    Laravel中的migrations文件存放的是数据库表文件等结构,可以说是一个跟git差不多的,可以说像是数据库的版本控制器,所以可以叫做迁移.因为它可以很快速的很容易地构建应用的数据库表结构. ...

  4. Laravel 5.2 数据库迁移和数据填充

    一.数据库迁移 Laravel 的数据库迁移提供了对数据库.表.字段.索引的一系列相关操作.下面以创建友情链接表为例. 1. 创建迁移 使用 Artisan 命令  php artisan make: ...

  5. laravel中的数据库迁移

    1.创建数据库迁移文件:生成数据库迁移文件,前面跟着时间戳: php artisan make:migration create_posts_table 创建数据库迁移文件:可以重命名数据表名: -- ...

  6. Laravel 5.4 数据库迁移一次之后就不起作用!

    https://segmentfault.com/q/1010000010806351 我在命令行中生成了一个新的迁移脚本: 当我执行命令:php artisan migrate 时 显示迁移成功,并 ...

  7. 数据库迁移(创建关联等操作) Target database is not up to date报错

    使用Mysql-sqlalchemy执行数据库迁移 来更新数据库: 队长试探性的在网上找了几种方案 依然没有解决报错问题: 后来看了https://www.aliyun.com/jiaocheng/4 ...

  8. 必须会的SQL语句(二) 创建表、修改表结构、删除表

    1.创建数据库表 --使用哪个数据库,如果不写这一句是默认的数据库,也可以用鼠标选当前数据库 use testDB --创建表    Create Table tablename    (       ...

  9. MySQL 5.6学习笔记(数据库基本操作,查看和修改表的存储引擎)

    1. 数据库基本操作 1.1  查看数据库 查看数据库列表: mysql> show databases; +--------------------+ | Database | +------ ...

随机推荐

  1. phpstudy扩展mongoDB

    观察如下3个参数,即位数,ts/nts,vc9/vc11/……三条规则(一定要一一对应) 重要是,还要对应PHP的版本,我选的是5.6的对应的版本 去http://windows.php.net/do ...

  2. Django中的check指令和sqlmigrate指令

    官方文档的解释如下: Django 有一个自动执行数据库迁移并同步管理你的数据库结构的命令 - 这个命令是 migrate,我们马上就会接触它 - 但是首先,让我们看看迁移命令会执行哪些 SQL 语句 ...

  3. hdu 1281 棋盘游戏(二分图)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1281 每行每列作为节点,给可以放车的点将对应的行列连边,最多可放置的车即为建二分图后的最大匹配,跑一边 ...

  4. 265. 粉刷房子 II

    Q: A: 首先这题可以和粉刷房子这题一样解法,对于i号房子,遍历k种颜色,对于每一种,都去找i-1号房子除该颜色之外的最小花费.但上一题是3种颜色,总复杂度O(N),这题k种颜色,复杂度O(NK^2 ...

  5. Spring-Aop编程(三)-AspectJ

    AspectJ 1. 介绍 AspectJ是一个基于Java语言的AOP框架,Spring2.0以后新增了对AspectJ切点表达式支持,@AspectJ 是AspectJ1.5新增功能,通过JDK5 ...

  6. C语言特点有哪些?

    C语言的特点 : 1.简洁紧凑.灵活方便 C语言一共只有32个关键字,9种控制语句,程序书写自由,主要用小写字母表示.它把高级语言的基本结构和语句与低级语言的实用性结合起来. C 语言可以象汇编语言一 ...

  7. web学习---html,js,php,mysql一个动态网页获取流程

    使用bootstrap的cms模版系统搭建了一个信息管理系统.通过这个系统学习动态网页获取的工作流程. 抓包分析一个页面的数据请求流程如下图所示: 同样,对于需要向数据库插入数据,可以使用ajax接口 ...

  8. sublime不支持ascill编码办法

    1.按下组合键ctrl+shift+p,输入:install package,回车 2.在弹出的安装包框中搜索:ConvertToUTF8或者GBK Encoding Support,选择点击安装: ...

  9. Django报错 The serializer field might be named incorrectly and not match any Got AttributeError when attempting to get a value for field `author_for` on serializer `KnownledgeBaseListSerializer`

    1.问题描述,在设置,model部分字段的serialier时,出现如下报错 字段如下: # 知识库List class KnownledgeBaseListSerializer(serializer ...

  10. spring boot 配置logback日志之jdbcTemplate打印sql语句配置

    配置jdbcTemplate打印sql 用mybaties打印语句很好配置,后来用了JdbcTemplate就不知道怎么打印了,其实JdbcTemplate执行sql语句的过程会做打印sql语句的操作 ...