溫馨提示×

php數據庫搜索與正則表達式

PHP
小樊
95
2024-12-24 05:55:11
欄目: 編程語言

在PHP中,你可以使用數據庫搜索和正則表達式來查詢和過濾數據。這里我將向你展示如何使用這兩種方法。

首先,假設你有一個名為users的數據庫表,其中包含以下列:id,usernameemail。

  1. 數據庫搜索:

要使用數據庫搜索,你可以使用PHP的mysqliPDO擴展。以下是使用mysqli擴展進行數據庫搜索的示例:

<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

// 創建連接
$conn = new mysqli($servername, $username, $password, $dbname);

// 檢查連接
if ($conn->connect_error) {
    die("連接失敗: " . $conn->connect_error);
}

// 設置字符集為utf8以支持中文等多字節字符
$conn->set_charset("utf8");

// 搜索關鍵詞
$keyword = "John";

// 使用預處理語句進行數據庫搜索
$stmt = $conn->prepare("SELECT * FROM users WHERE username LIKE ?");
$stmt->bind_param("s", $keyword);
$stmt->execute();

// 獲取結果并輸出
$result = $stmt->get_result();
while ($row = $result->fetch_assoc()) {
    echo "ID: " . $row["id"] . " - Username: " . $row["username"] . " - Email: " . $row["email"] . "<br>";
}

// 關閉連接
$stmt->close();
$conn->close();
?>
  1. 正則表達式:

要使用正則表達式進行搜索,你可以使用PHP的preg_match()函數。以下是使用正則表達式搜索用戶名的示例:

<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

// 創建連接
$conn = new mysqli($servername, $username, $password, $dbname);

// 檢查連接
if ($conn->connect_error) {
    die("連接失敗: " . $conn->connect_error);
}

// 設置字符集為utf8以支持中文等多字節字符
$conn->set_charset("utf8");

// 搜索關鍵詞
$keyword = "John";

// 使用正則表達式進行搜索
$pattern = "/$keyword/";
$sql = "SELECT * FROM users WHERE username REGEXP ?";

$stmt = $conn->prepare($sql);
$stmt->bind_param("s", $pattern);
$stmt->execute();

// 獲取結果并輸出
$result = $stmt->get_result();
while ($row = $result->fetch_assoc()) {
    echo "ID: " . $row["id"] . " - Username: " . $row["username"] . " - Email: " . $row["email"] . "<br>";
}

// 關閉連接
$stmt->close();
$conn->close();
?>

在這兩個示例中,我們都從users表中搜索包含關鍵詞"John"的用戶。第一個示例使用預處理語句和LIKE操作符進行搜索,而第二個示例使用正則表達式和REGEXP操作符進行搜索。你可以根據自己的需求選擇合適的方法。

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女