Home PHP Framework Laravel How to operate the database in laravel

How to operate the database in laravel

Apr 21, 2023 am 10:05 AM

Laravel is a very excellent PHP framework that provides developers with many conveniences, such as simplifying coding, improving development efficiency, and easy maintenance. At the same time, Laravel also supports a variety of database operation methods, making it easier for developers to perform database operations. In this article, we will introduce how to perform database operations in the Laravel framework.

Step one: Set database information

First, we need to configure the database information in the Laravel project. It can be configured in the config/database.php file, which includes information such as database type, host address, port, database name, user name and password.

In Laravel, multiple databases can be supported. Therefore, configuration needs to be done in config/database.php, for example:

'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,
    ],
Copy after login

As you can see, two database connections are defined here: mysql and mysql2, which correspond to different databases.

The relevant configuration of each database can be specified in the .env file:

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
Copy after login

These configuration information will be used in the Laravel application.

Step 2: Build the model

In the Laravel framework, models can be used to interact with the database. A model is a class used to process data in a database. Using models can map database tables to a PHP class, allowing us to operate the database more conveniently.

Use Artisan command line tools to quickly generate models, for example:

php artisan make:model User
Copy after login

This will generate a model class named User in the app/Models directory, where you can define tables, primary keys, timestamp and other information.

namespace App\Models;

use Illuminate\Database\Eloquent\Model;

class User extends Model
{
    protected $table = 'user';
    protected $primaryKey = 'id';
    public $timestamps = true;
}
Copy after login

Step Three: Query Data

In Laravel, database queries can be easily performed through Eloquent ORM. Models make it easy to query a table. For example, you can use the following Eloquent method to get all records in the "User" table:

use App\Models\User;

$users = User::all();
Copy after login

When using the findOrFail method to find records, you can use this method with the model ID:

$user = User::findOrFail(1);
Copy after login

Query some When recording, you can use the where method:

use App\Models\User;

$users = User::where('name', 'John')->get();
Copy after login

You can also use other conditions to query, such as:

$user = User::where('name', 'John')->first();
Copy after login
$users = User::select('name')->distinct()->get();
Copy after login
$users = User::orderBy('name', 'desc')->take(10)->get();
Copy after login

Step 4: Insert data

Insert data in the Laravel framework very simple. When using the model to create new records, you can use the following code:

$user = new User;
$user->name = 'John';
$user->email = 'john@example.com';
$user->save();
Copy after login

You can also use the create method in a class to create multiple new records at once:

User::create([
    'name' => 'Jane',
    'email' => 'jane@example.com',
]);
Copy after login

Step 5: Update data

Updating data through models is also very easy. You can update a record through the following code:

$user = User::find(1);

$user->email = 'john.doe@example.com';

$user->save();
Copy after login

You can also update records in batches:

User::where('name', 'John')->update(['email' => 'john.doe@example.com']);
Copy after login

Step 6: Delete data

Deleting data is similar to updating data. If you want to delete a single record, please use the following command:

$user = User::find(1);

$user->delete();
Copy after login

When you need to delete multiple records, you can use the following command:

User::where('name', 'John')->delete();
Copy after login

Note that the delete method will permanently remove the record from the database delete. Instead of permanently deleting it, you can use the soft delete feature to move it to another table.

Summary

Laravel ORM provides programmers with a powerful tool to operate databases. Through the above steps, you can easily perform database queries, inserts, updates, and deletes. It is worth noting that sensitive data should be handled with great care and good behavior. I hope this article will be helpful to you when operating databases in Laravel.

The above is the detailed content of How to operate the database in laravel. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to Build a RESTful API with Advanced Features in Laravel? How to Build a RESTful API with Advanced Features in Laravel? Mar 11, 2025 pm 04:13 PM

This article guides building robust Laravel RESTful APIs. It covers project setup, resource management, database interactions, serialization, authentication, authorization, testing, and crucial security best practices. Addressing scalability chall

How to Implement OAuth2 Authentication and Authorization in Laravel? How to Implement OAuth2 Authentication and Authorization in Laravel? Mar 12, 2025 pm 05:56 PM

This article details implementing OAuth 2.0 authentication and authorization in Laravel. It covers using packages like league/oauth2-server or provider-specific solutions, emphasizing database setup, client registration, authorization server configu

How do I use Laravel's components to create reusable UI elements? How do I use Laravel's components to create reusable UI elements? Mar 17, 2025 pm 02:47 PM

The article discusses creating and customizing reusable UI elements in Laravel using components, offering best practices for organization and suggesting enhancing packages.

What Are the Best Practices for Using Laravel in a Cloud-Native Environment? What Are the Best Practices for Using Laravel in a Cloud-Native Environment? Mar 14, 2025 pm 01:44 PM

The article discusses best practices for deploying Laravel in cloud-native environments, focusing on scalability, reliability, and security. Key issues include containerization, microservices, stateless design, and optimization strategies.

How do I create and use custom Blade directives in Laravel? How do I create and use custom Blade directives in Laravel? Mar 17, 2025 pm 02:50 PM

The article discusses creating and using custom Blade directives in Laravel to enhance templating. It covers defining directives, using them in templates, and managing them in large projects, highlighting benefits like improved code reusability and r

How can I create and use custom validation rules in Laravel? How can I create and use custom validation rules in Laravel? Mar 17, 2025 pm 02:38 PM

The article discusses creating and using custom validation rules in Laravel, offering steps to define and implement them. It highlights benefits like reusability and specificity, and provides methods to extend Laravel's validation system.

Laravel vs. Symfony: Which Is Right for Your Web App? Laravel vs. Symfony: Which Is Right for Your Web App? Mar 10, 2025 pm 01:34 PM

When it comes to choosing a PHP framework, Laravel and Symfony are among the most popular and widely used options. Each framework brings its own philosophy, features, and strengths to the table, making them suited for different projects and use cases. Understanding their differences and similarities is critical to selecting the right framework for your development needs.

What Are the Best Ways to Handle File Uploads and Cloud Storage in Laravel? What Are the Best Ways to Handle File Uploads and Cloud Storage in Laravel? Mar 12, 2025 pm 05:54 PM

This article explores optimal file upload and cloud storage strategies in Laravel. It examines local storage vs. cloud providers (AWS S3, Google Cloud, Azure, DigitalOcean), emphasizing security (validation, sanitization, HTTPS) and performance opti

See all articles