首页 > php框架 > Laravel > laravel数据表怎么设置

laravel数据表怎么设置

王林
发布: 2023-05-29 09:30:07
原创
662 人浏览过

Laravel是现代PHP开发中最流行的框架之一。它提供了许多有用的功能和工具,其中最重要的是它的ORM。可以使用ORM(对象关系映射)轻松地操作数据库。在Laravel中,使用ORM建立数据表并且设置数据表的方法非常简单。在本文中,我们将讨论如何使用Laravel来设置数据表。

Laravel数据库迁移

在Laravel中,数据表的设置是通过数据库迁移(database migration)来完成的。数据库迁移是一种版本控制,用于管理数据表的结构变化。每一个迁移都描述了数据库模式的变化。每个版本控制迁移都呈现了一次数据库升级,所以你可以回到之前的版本或者升级到较新的版本。更重要的是,Laravel提供了便捷的命令行功能来创建和管理迁移。这样你就可以很容易地向数据库添加或删除表格。因此,在这个过程中,你不必手动编写SQL代码。

Laravel迁移的创建

首先,在Laravel中创建迁移非常简单。可以使用以下命令来创建一个新迁移:

php artisan make:migration create_users_table
登录后复制

这个命令将创建一个新的迁移,名为“create_users_table”。迁移将保存在“database/migrations”目录下。这个目录就是Laravel框架自带的数据库迁移目录。

打开刚创建的迁移。你将看到一个空的“up”方法,这是当你迁移时执行的代码。下面是这个方法的简单的结构:

public function up()
{
    //
}
登录后复制

在这个方法中,你可以编写用于创建数据表的代码。我们将在下面的示例中解释。

Laravel数据类型

在Laravel中,有多种数据类型可供选择,用于描述数据表列的类型。在下面的示例中,我们将介绍一些可用的数据类型。

1.自增ID

$table->bigIncrements('id')

2.整数

$table->integer('age')

3.长整数

$table->bigInteger('views')

4.小数

$table->decimal('price', 5, 2)

5.字符串

$table->string('name')

6.长文本

$table->longText('description')

7.日期

$table->date('dob')

8.日期时间

$table->dateTime('published_at')

9.布尔

$table->boolean('is_active')

10.JSON

$table->json('options')

11.时间戳

$table->timestamps()

Laravel数据表的设置

使用上面的命令创建迁移并打开“up”方法。接下来,你需要设置数据表的名称、列以及它们的类型和其他细节。下面是如何设置一个名为“users”的数据表:

public function up()
{
    Schema::create('users', function (Blueprint $table) {
        $table->bigIncrements('id');
        $table->string('name');
        $table->string('email')->unique();
        $table->timestamp('email_verified_at')->nullable();
        $table->string('password');
        $table->rememberToken();
        $table->timestamps();
    });
}
登录后复制

在上述代码中,我们通过调用“Schema::create”方法来创建数据表。在调用“Schema::create”方法时,我们需要传递数据表名称和一个回调方法,这个回调方法用于描述这个数据表的列和其他细节。在回调方法中,使用“Blueprint”类创建列。如,我们创建了一个名称为“id”的自增列,并且这个列是此数据表的主键。列的名称使用字符串来表示,列的类型可以使用上面列出的任何数据类型。

调用“Schema::create”方法将在数据库中创建一个名为“users”的表。如果数据表已经存在,你仍然可以使用这个命令来向它添加更多的列或更改它的结构。为了完成这个任务,你需要使用“Schema::table”方法,并在回调函数中指定更改。

例如,下面的代码将向名为“users”的数据表添加一个名为“phone”的列:

public function up()
{
    Schema::table('users', function (Blueprint $table) {
        $table->string('phone')->after('email');
    });
}
登录后复制

在上面的代码中,我们通过调用“Schema::table”方法来更改名为“users”的数据表。更改的详情是让迁移创建一个名为“phone”的列,并且将其放置在“email”列之后。

Laravel迁移的运行

现在,我们已经创建了一个简单的数据表。接下来,我们需要运行迁移并将更改保存到数据库中。要运行迁移,请使用以下命令:

php artisan migrate
登录后复制

这个命令将运行所有尚未运行的迁移。

Laravel迁移的回滚

Laravel提供了一个方便的问题回滚命令,它用于撤回之前运行的迁移。在撤回迁移时,Laravel会自动恢复更改前版本的数据表结构。要回滚一个迁移,请使用以下命令:

php artisan migrate:rollback
登录后复制

这个命令将回滚最后一个迁移。如果你想撤回更多的迁移,请使用“--step”参数和数字来指定要回滚的迁移数量。例如:

php artisan migrate:rollback --step=2
登录后复制

这个命令将回滚最后两个迁移。

总结

Laravel提供了一种简便方法来管理数据库结构变化。使用数据库迁移,可以轻松地向Laravel应用程序添加或删除数据表,这是为保持良好的版本控制而必需的。在本文中,我们讨论了在Laravel中如何创建和设置数据表,以及如何运行和回滚迁移。如果你遵循这些步骤,你将能够在Laravel中轻松地创建和管理数据表。

以上是laravel数据表怎么设置的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板