laravel 修改数据库

laravel是一款极受欢迎的php web应用程序框架,它提供了丰富的工具和功能,使开发人员能够轻松构建出高效、易于维护的web应用程序。而其中一个关键的功能就是与数据库的交互操作。在使用laravel进行开发时,我们经常需要对数据库进行修改或者更新,本篇文章就将带大家详细了解laravel修改数据库的相关操作。

一、Laravel数据库迁移

Laravel提供了数据库迁移(Migration)功能,使得我们可以轻松的管理数据库的版本控制。通过数据库迁移,我们可以定义数据库表结构的变化,并通过框架提供的命令快速迁移至新版本的数据库。具体步骤如下:

  1. 创建数据库迁移文件

Laravel的迁移文件存储在database/migrations目录下,我们可以使用Artisan命令来生成迁移文件。执行以下命令可以创建一个名为create_users_table的迁移文件:

php artisan make:migration create_users_table

  1. 编写迁移脚本

打开刚刚生成的迁移文件(位于database/migrations目录下),可以看到有一个up函数和一个down函数。up函数用于执行迁移操作,而down函数用于撤销迁移操作。

我们可以在up函数中编写创建数据库表的脚本,例如:

Schema::create(‘users’, function (Blueprint $table) {
$table->increments(‘id’);
$table->String(‘name’);
$table->string(’email’)->unique();
$table->timestamp(’email_verified_at’)->Nullable();
$table->string(‘password’);
$table->rememberToken();
$table->timestamps();
});

该脚本将创建一个名为users的数据表,该表包含id、name、email、email_verified_at、password、remember_token和timestamps等7个字段。

  1. 运行迁移脚本

编写完迁移脚本后,我们可以通过以下命令来运行迁移脚本:

php artisan migrate

此时,Laravel框架会自动根据我们编写的脚本来创建表结构,如果数据库中已经存在了相关表,框架会自动跳过不会执行。

二、Laravel数据库填充

数据库填充是Laravel提供的另一个重要功能,可以帮助我们在开发、测试和生产环境中用假数据填充数据库。例如,当我们需要测试数据的查询性能时,可以使用填充来填充大量数据。

  1. 创建数据填充文件

我们可以使用Artisan命令来创建填充文件,如下:

php artisan make:seeder UsersTableSeeder

  1. 编写填充脚本

将编写的填充脚本放到database/seeds目录下,在UsersTableSeeder中编写如下代码:

use IlluminateDatabaseSeeder;
use IlluminateSupportFacadesDB;
use IlluminateSupportFacadesHash;
use IlluminateSupportStr;

class UsersTableSeeder extends Seeder
{

/**  * Run the database seeds.  *  * @return void  */ public function run() {     DB::table('users')->insert([         'name' => Str::random(10),         'email' => Str::random(10).'@gmail.com',         'password' => Hash::make('password'),     ]); }

}

该脚本会向users表中插入一条记录,包含name、email、password三个字段,其中name和email字段的值是随机生成的。

  1. 运行填充脚本

我们可以通过以下命令来运行填充脚本:

php artisan db:seed

此时,Laravel框架会自动调用我们编写的填充脚本,然后将数据插入到users表中。

三、Laravel数据库操作

除了使用数据库迁移和数据填充来修改数据库外,我们还可以使用Laravel提供的DB类来进行数据操作。

  1. 插入数据

DB::table(‘users’)->insert([

'name' => 'John Doe', 'email' => 'johndoe@example.com', 'password' => Hash::make('password'),

]);

该脚本会向users表中插入一条记录,包含name、email、password三个字段,其中name和email字段的值都是指定的。

  1. 更新数据

DB::table(‘users’)

->where('id', 1) ->update(['votes' => 1]); 

该语句将会将id为1的记录中的votes字段值设为1。

  1. 删除数据

DB::table(‘users’)->where(‘votes’, ‘delete();

该语句将会删除votes字段值小于100的所有记录。

四、结语

本文介绍了Laravel如何修改数据库,分别介绍了数据库迁移、数据库填充和数据库操作等三种方式。Laravel中处理数据库的简单和高效性使其成为了流行的Web框架之一,对于开发人员来说,学习这些相关功能也是非常必要的。

© 版权声明
THE END
喜欢就支持一下吧
点赞8 分享