Home Backend Development PHP Problem How to implement deletion of data function in PHP

How to implement deletion of data function in PHP

Mar 31, 2023 am 09:05 AM

PHP is a server-side scripting language widely used in web development, especially dynamic page generation. In web development, we often need to delete data from the database. PHP provides us with a variety of ways to delete data. This article will introduce several commonly used ways to delete data in PHP.

  1. Using the DELETE statement

The DELETE statement is a common way to delete data in the database. In PHP, we can use mysqli extension or PDO extension to execute DELETE statement.

Use mysqli extension:

$mysqli = new mysqli("localhost", "username", "password", "database");

// 检查连接是否成功
if ($mysqli->connect_errno) {
  echo "连接 MySQL 失败:" . $mysqli->connect_error;
}

// 执行 DELETE 语句
$sql = "DELETE FROM users WHERE id=1";
if ($mysqli->query($sql) === TRUE) {
  echo "删除成功";
} else {
  echo "Error: " . $sql . "<br>" . $mysqli->error;
}

// 关闭连接
$mysqli->close();
Copy after login

Use PDO extension:

$dsn = "mysql:host=localhost;dbname=database";
$username = "username";
$password = "password";

try {
  $pdo = new PDO($dsn, $username, $password);
  $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

  // 执行 DELETE 语句
  $sql = "DELETE FROM users WHERE id=:id";
  $stmt = $pdo->prepare($sql);
  $stmt->bindParam(':id', $id);
  $stmt->execute();

  echo "删除成功";
} catch(PDOException $e) {
  echo "Error: " . $e->getMessage();
}

// 关闭连接
$pdo = null;
Copy after login

In the above example, we directly hardcoded the deletion condition (id=1). This is not advisable in practical applications, and parameterized queries should be used to bind input variables for deletion operations.

  1. Using the ORM framework

ORM (Object-Relational Mapping) is a programming technology that maps tables in a relational database to classes or objects in a programming language. And it realizes the encapsulation, inheritance, polymorphism and other features of object-oriented programming. Using the ORM framework, database operations can be greatly simplified.

The following takes the Laravel framework as an example to show the usage process of the ORM framework. In Laravel, we can define a data model and use the model to perform database operations. For example, we have a user (User) data table, we can define the following data model:

namespace App;

use Illuminate\Database\Eloquent\Model;

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

In the above example, we defined a User model, specified the users data table, and specified the primary key as id. We also turned off the ability to automatically update timestamps ($timestamps=false).

To use the model to delete data, you only need to call the delete method of the model:

$user = User::find(1); // 查询id为1的用户
if ($user) {
  $user->delete(); // 删除该用户
  echo "删除成功";
} else {
  echo "用户不存在";
}
Copy after login

The attributes and methods defined in the model encapsulate some underlying database operations for us, simplifying our code.

  1. Using relational databases

Relational databases (such as MySQL, Oracle, SQL Server, etc.) support defining constraints between tables, such as primary keys, foreign keys, etc. When using a relational database, you can delete data by setting "cascade delete" constraints.

Cascade deletion means that when a record in the parent table is deleted, all records in its associated child tables are also deleted. This reduces the amount of code while avoiding data inconsistencies due to program errors or exceptions. For example, we have an Orders data table and an OrderDetails data table. We can set a foreign key in the Order Details table to associate the primary key of the Orders table, and set a "cascade delete" constraint. The code is as follows:

CREATE TABLE Orders (
  order_id INT PRIMARY KEY AUTO_INCREMENT,
  customer_id INT NOT NULL,
  order_date DATE NOT NULL
);

CREATE TABLE OrderDetails (
  order_id INT NOT NULL,
  product_id INT NOT NULL,
  quantity INT NOT NULL,
  CONSTRAINT pk_OrderDetails PRIMARY KEY (order_id, product_id),
  CONSTRAINT fk_OrderDetails_Orders FOREIGN KEY (order_id)
    REFERENCES Orders(order_id)
    ON DELETE CASCADE
);
Copy after login

In the above code, we created two data tables, associated the order details table with the order table, and set the "cascade delete" constraint. When we execute the following SQL statement, we can delete the order and order details at the same time:

DELETE FROM Orders WHERE order_id=1;
Copy after login

In web development, deleting data is an essential operation. The above methods can all realize the function of data deletion. We can choose the most suitable method to meet the needs according to the actual situation.

The above is the detailed content of How to implement deletion of data function in PHP. 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

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

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)

PHP 8 JIT (Just-In-Time) Compilation: How it improves performance. PHP 8 JIT (Just-In-Time) Compilation: How it improves performance. Mar 25, 2025 am 10:37 AM

PHP 8's JIT compilation enhances performance by compiling frequently executed code into machine code, benefiting applications with heavy computations and reducing execution times.

OWASP Top 10 PHP: Describe and mitigate common vulnerabilities. OWASP Top 10 PHP: Describe and mitigate common vulnerabilities. Mar 26, 2025 pm 04:13 PM

The article discusses OWASP Top 10 vulnerabilities in PHP and mitigation strategies. Key issues include injection, broken authentication, and XSS, with recommended tools for monitoring and securing PHP applications.

PHP Secure File Uploads: Preventing file-related vulnerabilities. PHP Secure File Uploads: Preventing file-related vulnerabilities. Mar 26, 2025 pm 04:18 PM

The article discusses securing PHP file uploads to prevent vulnerabilities like code injection. It focuses on file type validation, secure storage, and error handling to enhance application security.

PHP Encryption: Symmetric vs. asymmetric encryption. PHP Encryption: Symmetric vs. asymmetric encryption. Mar 25, 2025 pm 03:12 PM

The article discusses symmetric and asymmetric encryption in PHP, comparing their suitability, performance, and security differences. Symmetric encryption is faster and suited for bulk data, while asymmetric is used for secure key exchange.

How do you retrieve data from a database using PHP? How do you retrieve data from a database using PHP? Mar 20, 2025 pm 04:57 PM

Article discusses retrieving data from databases using PHP, covering steps, security measures, optimization techniques, and common errors with solutions.Character count: 159

PHP Authentication & Authorization: Secure implementation. PHP Authentication & Authorization: Secure implementation. Mar 25, 2025 pm 03:06 PM

The article discusses implementing robust authentication and authorization in PHP to prevent unauthorized access, detailing best practices and recommending security-enhancing tools.

What is the purpose of prepared statements in PHP? What is the purpose of prepared statements in PHP? Mar 20, 2025 pm 04:47 PM

Prepared statements in PHP enhance database security and efficiency by preventing SQL injection and improving query performance through compilation and reuse.Character count: 159

PHP CSRF Protection: How to prevent CSRF attacks. PHP CSRF Protection: How to prevent CSRF attacks. Mar 25, 2025 pm 03:05 PM

The article discusses strategies to prevent CSRF attacks in PHP, including using CSRF tokens, Same-Site cookies, and proper session management.

See all articles