php 如何通過mysqli操作數據庫?

在PHP中,mysqli(MySQL Improved Extension)是操作MySQL數據庫的擴展庫,提供了面向對象和過程式兩種風格。以下是mysqli的基本操作方法:

1. 連接數據庫

面向對象風格
$mysqli = new mysqli('localhost', 'username', 'password', 'database_name');// 檢查連接是否成功
if ($mysqli->connect_error) {die("連接失敗: " . $mysqli->connect_error);
}echo "連接成功";
過程式風格
$conn = mysqli_connect('localhost', 'username', 'password', 'database_name');if (!$conn) {die("連接失敗: " . mysqli_connect_error());
}echo "連接成功";

2. 執行查詢(SELECT)

// 準備SQL語句
$sql = "SELECT id, name, email FROM users";
$result = $mysqli->query($sql);// 檢查查詢結果
if ($result->num_rows > 0) {// 輸出數據while ($row = $result->fetch_assoc()) {echo "ID: " . $row["id"] . " - Name: " . $row["name"] . " - Email: " . $row["email"] . "<br>";}
} else {echo "0 結果";
}// 釋放結果集
$result->free();

3. 預處理語句(防止SQL注入)

// 準備SQL語句
$sql = "SELECT id, name, email FROM users WHERE age > ?";
$stmt = $mysqli->prepare($sql);// 綁定參數
$age = 18;
$stmt->bind_param("i", $age); // "i" 表示整數類型// 執行查詢
$stmt->execute();// 獲取結果
$result = $stmt->get_result();// 處理結果
while ($row = $result->fetch_assoc()) {echo "ID: " . $row["id"] . " - Name: " . $row["name"] . "<br>";
}// 關閉預處理語句
$stmt->close();

4. 插入數據

// 準備SQL語句
$sql = "INSERT INTO users (name, email, age) VALUES (?, ?, ?)";
$stmt = $mysqli->prepare($sql);// 綁定參數
$name = "John Doe";
$email = "john@example.com";
$age = 30;
$stmt->bind_param("ssi", $name, $email, $age); // "ssi" 表示兩個字符串和一個整數// 執行插入
if ($stmt->execute()) {echo "新記錄插入成功,ID: " . $stmt->insert_id;
} else {echo "Error: " . $stmt->error;
}// 關閉預處理語句
$stmt->close();

5. 更新數據

// 準備SQL語句
$sql = "UPDATE users SET age = ? WHERE id = ?";
$stmt = $mysqli->prepare($sql);// 綁定參數
$newAge = 31;
$id = 1;
$stmt->bind_param("ii", $newAge, $id);// 執行更新
if ($stmt->execute()) {echo "記錄更新成功,受影響的行數: " . $stmt->affected_rows;
} else {echo "Error: " . $stmt->error;
}// 關閉預處理語句
$stmt->close();

6. 刪除數據

// 準備SQL語句
$sql = "DELETE FROM users WHERE id = ?";
$stmt = $mysqli->prepare($sql);// 綁定參數
$id = 1;
$stmt->bind_param("i", $id);// 執行刪除
if ($stmt->execute()) {echo "記錄刪除成功,受影響的行數: " . $stmt->affected_rows;
} else {echo "Error: " . $stmt->error;
}// 關閉預處理語句
$stmt->close();

7. 事務處理

// 開始事務
$mysqli->begin_transaction();try {// 執行多個SQL操作$mysqli->query("UPDATE accounts SET balance = balance - 100 WHERE id = 1");$mysqli->query("UPDATE accounts SET balance = balance + 100 WHERE id = 2");// 提交事務$mysqli->commit();echo "事務執行成功";
} catch (Exception $e) {// 回滾事務$mysqli->rollback();echo "事務失敗: " . $e->getMessage();
}

8. 關閉連接

$mysqli->close();

mysqli與PDO的對比

特性mysqliPDO
數據庫支持僅MySQL支持多種數據庫(MySQL、PostgreSQL等)
面向對象支持(也支持過程式)僅面向對象
預處理語句支持支持
錯誤處理支持異常模式支持異常模式
事務處理支持支持
跨數據庫兼容性

總結

  • mysqli是專門為MySQL設計的擴展,性能略高。
  • 預處理語句是防止SQL注入的關鍵,強烈推薦使用。
  • 事務處理可確保數據的一致性。
  • 對于跨數據庫項目,建議使用PDO。

以上示例展示了mysqli的基本用法,實際開發中建議結合異常處理和預處理語句,提高代碼的安全性和可維護性。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/88409.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/88409.shtml
英文地址,請注明出處:http://en.pswp.cn/web/88409.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

c/c++拷貝函數

memcpy()函數概要原型void * memcpy ( void * dest, const void * src, size_t num );功能memcpy()會復制 src 所指的內存內容的前 num 個字節到 dest所指的內存地址上&#xff08;memcpy()并不關心被復制的數據類型&#xff0c;只是逐字節地進行復制&#xff0c;這給函數的使用…

HTTP核心基礎詳解(附實戰要點)

目錄 一圖勝千言&#xff1a;HTTP核心機制圖解?編輯 一、HTTP本質&#xff1a;通信的橋梁 二、五大核心特性解析 三、HTTP頭部&#xff1a;隱藏的控制中心 四、連接管理&#xff1a;性能關鍵點 開發者必知實踐技巧 一圖勝千言&#xff1a;HTTP核心機制圖解 一、HTTP本質…

華為靜態路由配置

問題描述&#xff1a;針對兩臺筆記本和兩個路由器在不同的網段場景中&#xff0c;對兩個路由器進行靜態路由配置。下面以如下場景為例&#xff0c;介紹詳細配置過程。配置步驟&#xff1a; 1、對每個路由器的接口下配置IP地址 [huawei]interface gx/x/x [huawei-interface]ip a…

閑庭信步使用圖像驗證平臺加速FPGA的開發:第八課——圖像數據的行緩存

&#xff08;本系列只需要modelsim即可完成數字圖像的處理&#xff0c;每個工程都搭建了全自動化的仿真環境&#xff0c;只需要雙擊文件就可以完成整個的仿真&#xff0c;大大降低了初學者的門檻&#xff01;&#xff01;&#xff01;&#xff01;如需要該系列的工程文件請關注…

經典排序算法

文章目錄前言1. 排序的基本概念1.1 排序是什么&#xff1f;1.2 常見的排序算法概覽2. 常見排序算法的實現2.1 插入排序 (Insertion Sort)2.1.1 基本思想2.1.2 直接插入排序2.1.3 希爾排序 (Shell Sort)2.2 選擇排序 (Selection Sort)2.2.1 直接選擇排序2.2.2 堆排序 (Heap Sort…

RabbitMQ 消息隊列:從入門到Spring Boot實戰

RabbitMQ 作為一款開源的、基于 AMQP&#xff08;Advanced Message Queuing Protocol&#xff09;協議實現的消息代理&#xff0c;憑借其強大的功能、靈活的路由機制以及出色的性能&#xff0c;在業界得到了廣泛的應用。無論是處理高并發訂單、異步通知、日志收集還是系統解耦&…

代賬行業數字化破局:從“知道”到“做到”,三步走穩贏!

認知&#xff01;降本&#xff01;增收&#xff01;數字化&#xff01;——這不僅是口號&#xff0c;更是代賬行業在激烈競爭和時代變化中生存發展的關鍵。很多代賬同行其實都明白趨勢&#xff0c;也知道大概該怎么做。但問題卡在第一步&#xff1a;不知道怎么開始&#xff0c;…

Mac 電腦crontab執行定時任務【Python 實戰】

1、crontab -e 編輯定時任務列表 crontab -e查看當前定時任務列表,長按 i 編輯,編輯完之后按 esc 退出編輯,然后輸入:wq 保存并提出。 如下: (base) charles@zl ~ % crontab -e58 15 * * * /Library/Frameworks/Python.framework/Versions/3.8/bin/python3 /Users/charle…

go go go 出發咯 - go web開發入門系列(三) 項目基礎框架搭建與解讀

go go go 出發咯 - go web開發入門系列&#xff08;三&#xff09; 項目基礎框架搭建與解讀 往期回顧 go go go 出發咯 - go web開發入門系列&#xff08;一&#xff09; helloworldgo go go 出發咯 - go web開發入門系列&#xff08;二&#xff09; Gin 框架實戰指南 前言 如…

【字節跳動】數據挖掘面試題0014:SQL中count(1), count(*), count(列)區別

文章大綱SQL 中 count(1)、count(*)、count(某列) 的區別一、核心定義與行為差異二、示例說明差異三、性能差異與優化四、適用場景建議五、面試應答要點六、索引掃描與全表掃描1. 索引掃描的觸發條件2. 全表掃描的適用場景3. 常見面試問題點Q1&#xff1a;索引掃描一定比全表掃…

Linux面試問題-軟件測試

1、你在上一家公司常用的Linux命令有哪些&#xff1f;答&#xff1a;使用vim/vi編輯文件&#xff0c;使用cat&#xff0c;more,less&#xff0c;head查看文件&#xff0c;使用grep過濾日志中的error,使用ps查看進程&#xff0c;使用top查看實時進程&#xff0c;netstat查看端口…

時序數據庫的存儲之道:從數據特性看技術要點

時序數據的獨特挑戰時序數據(Time-Series Data)是指按時間順序記錄的一系列數據點&#xff0c;在物聯網、金融、工業監控等領域無處不在。與傳統數據相比&#xff0c;時序數據具有幾個鮮明特點&#xff1a;時間導向性&#xff1a;每個數據點都帶有精確的時間戳高寫入量&#xf…

【vim中替換】

vim中替換1 : s/在Vim中經常高頻使用到的命令&#xff1a;1 : s/ &#xff1a;s 命令的基本語法是 :[range]s/{pattern}/{string}/[flags]&#xff0c;其中&#xff1a; ? [range] 是可選的范圍&#xff0c;用于指定替換的行范圍。例如&#xff0c;% 表示全文&#xff0c;10,…

Qt實戰:使用QSqlDatabase連接MySQL,并實現增刪改查

文章目錄一、創建數據表二、連接MySQL數據庫三、封裝成一個完整的輕量級 ORM 風格類四、實現派生具體模型類五、支持多線程連接池 ORM 事務封裝一、創建數據表 數據庫名&#xff1a; 我們先創建一個數據庫&#xff0c;名字叫 game_db&#xff1a; CREATE DATABASE IF NOT E…

Python腳本保護工具庫之pyarmor使用詳解

概要 PyArmor是一個專門為Python代碼提供加密保護的第三方庫,旨在解決Python源代碼易被反編譯和泄露的安全問題。作為一種動態代碼保護工具,PyArmor能夠對Python腳本進行混淆和加密處理,有效防止源代碼被惡意獲取、分析或篡改。該庫特別適用于商業軟件開發、知識產權保護和…

倉頡編程語言:從入門到精通

為啥要瞅瞅倉頡這玩意兒&#xff1f; 有一說一&#xff0c;現在的編程語言多得跟米一樣&#xff0c;對吧&#xff1f;那一門新語言想火&#xff0c;沒點絕活兒肯定不行。倉頡&#xff08;Cangjie&#xff09;這哥們兒&#xff0c;是華為搞出來的新玩意兒&#xff0c;靜態編譯的…

線性探針是什么:是一種用于探測神經網絡中特定特征的工具

線性探針是什么 線性探針是一種在機器學習和相關領域廣泛應用的技術,用于評估預訓練模型特征、檢測數據中的特定序列等。在不同的應用場景下,線性探針有著不同的實現方式和作用: 評估預訓練模型特征:在機器學習中,線性探針是一種評估預訓練模型“特征遷移能力”的標準化方…

【論文閱讀】Few-Shot PPG Signal Generation via Guided Diffusion Models

從少量樣本數據選擇到后處理的整體框架。首先,擴散模型在N樣本數據集和指導下的訓練。接著,模型生成一個增強的數據集,并進一步優化以提高保真度。最后,這些合成數據與少量樣本訓練數據集結合,用于基準模型的訓練和評估。數據分布從最初的紅色變為保真度增強的藍色,這表明…

CentOS-7的“ifupdown“與Debian的“ifupdown“對比 筆記250706

CentOS-7的"ifupdown"與Debian的"ifupdown"對比 筆記250706 CentOS 7 和 Debian 的 ifupdown 工具名稱相同&#xff0c;但在實現機制、配置文件語法和系統集成上存在顯著差異。以下是核心對比分析&#xff1a; ?? 一、核心差異概覽 對比維度CentOS 7De…

架構如傳承:技術長河中的可持續樂章

代碼結構&#xff1a;協作基石 在軟件開發的世界里&#xff0c;代碼結構就如同建筑的框架&#xff0c;支撐著整個項目的運行。想象一下&#xff0c;你加入了一個新的開發團隊&#xff0c;接手一個已經有一定規模的項目。當你打開代碼庫&#xff0c;看到的是一團亂麻般的代碼&a…