这篇文章主要介绍“laravel如何操作数据库”,在日常操作中,相信很多人在laravel如何操作数据库问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”laravel如何操作数据库”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
第一步:设置数据库信息
首先,我们需要在Laravel项目中配置数据库信息。可以在config/database.php文件中进行配置,其中包括数据库类型、主机地址、端口、数据库名、用户名和密码等信息。
在Laravel中,可以支持多个数据库。因此,需要在config/database.php 中进行配置,例如:
'connections' => [
'mysql' => [
'driver' => 'mysql',
'host' => env('DB_HOST', '127.0.0.1'),
'port' => env('DB_PORT', '3306'),
'database' => env('DB_DATABASE', 'forge'),
'username' => env('DB_USERNAME', 'forge'),
'password' => env('DB_PASSWORD', ''),
'unix_socket' => env('DB_SOCKET', ''),
'charset' => 'utf8mb4',
'collation' => 'utf8mb4_unicode_ci',
'prefix' => '',
'strict' => true,
'engine' => null,
],
'mysql2' => [
'driver' => 'mysql',
'host' => env('DB2_HOST', '127.0.0.1'),
'port' => env('DB2_PORT', '3306'),
'database' => env('DB2_DATABASE', 'forge'),
'username' => env('DB2_USERNAME', 'forge'),
'password' => env('DB2_PASSWORD', ''),
'unix_socket' => env('DB2_SOCKET', ''),
'charset' => 'utf8mb4',
'collation' => 'utf8mb4_unicode_ci',
'prefix' => '',
'strict' => true,
'engine' => null,
],
可以看到,这里定义了两个数据库连接:mysql和mysql2,它们分别对应不同的数据库。
在.env文件中可以指定每个数据库的相关配置:
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=database_name
DB_USERNAME=database_username
DB_PASSWORD=database_password
DB_CONNECTION=mysql2
DB_HOST=127.0.0.1
DB_PORT=3306
DB2_DATABASE=database2_name
DB2_USERNAME=database2_username
DB2_PASSWORD=database2_password
这些配置信息将在Laravel应用程序中使用。
第二步:建立模型
在Laravel框架中,模型可用于与数据库交互。模型是一个类,用于处理数据库中的数据。使用模型可以把数据库的表映射到一个PHP类中,使我们能够更方便地操作数据库。
使用Artisan命令行工具来快速生成模型,例如:
php artisan make:model User
这将在app/Models目录下生成一个名为User的模型类,可以在其中定义表、主键、时间戳等信息。
namespace AppModels;
use IlluminateDatabaseEloquentModel;
class User extends Model
{
protected $table = 'user';
protected $primaryKey = 'id';
public $timestamps = true;
}
第三步:查询数据
在Laravel中,通过Eloquent ORM可以方便地进行数据库查询。通过模型可以轻松地查询某个表。例如使用以下Eloquent方法可以获取“User”表中的所有记录:
use AppModelsUser;
$users = User::all();
使用findOrFail方法查找记录时,可以将该方法与模型ID一起使用:
$user = User::findOrFail(1);
查询某些记录时,可以使用where方法:
use AppModelsUser;
$users = User::where('name', 'John')->get();
还可以使用其他条件进行查询,例如:
$user = User::where('name', 'John')->first();
$users = User::select('name')->distinct()->get();
$users = User::orderBy('name', 'desc')->take(10)->get();
第四步:插入数据
在Laravel框架中插入数据非常简单。使用模型创建新记录时,可以使用以下代码:
$user = new User;
$user->name = 'John';
$user->email = 'john@example.com';
$user->save();
还可以在一个类中使用create方法一次创建多个新记录:
User::create([
'name' => 'Jane',
'email' => 'jane@example.com',
]);
第五步:更新数据
通过模型更新数据也非常容易。可以通过以下代码更新一个记录:
$user = User::find(1);
$user->email = 'john.doe@example.com';
$user->save();
也可以批量更新记录:
User::where('name', 'John')->update(['email' => 'john.doe@example.com']);
第六步:删除数据
删除数据与更新数据的方法类似。如果您要删除单个记录,请使用以下命令:
$user = User::find(1);
$user->delete();
当需要删除多个记录时,可以使用以下命令:
User::where('name', 'John')->delete();
注意,delete方法会将记录从数据库中永久删除。可以使用软删除功能将其移动到另一个表中,而不是永久删除。