php操縱mysqli資料庫

来源:http://www.cnblogs.com/qizekai/archive/2016/09/18/5880396.html
-Advertisement-
Play Games

從php5.0開始增加mysql(i)支持 , 新加的功能都以對象的形式添加 i表示改進的意思 功能多、效率高、穩定 編譯時參數: ./configure --with-mysql=/usr/bin/mysql_config \ #使用 Mysql ClientLibrary(libmysql)構建 ...


從php5.0開始增加mysql(i)支持 , 新加的功能都以對象的形式添加

i表示改進的意思 功能多、效率高、穩定

編譯時參數:

./configure --with-mysql=/usr/bin/mysql_config \ #使用 Mysql ClientLibrary(libmysql)構建
--with-mysqli=mysqlnd \ #使用 Mysql Native Dirver 即mysqlnd
--with-pdo-mysql=mysqlnd #使用 Mysql Native Dirver 即mysqlnd

由於版權問題 從 php5.3開始 php開始用 mysqlnd 替代 libmysql.dll 
mysqlnd 是zend公司開發的mysql資料庫驅動,相比原來各方面都有所提高

#使用mysqlnd編譯

./configure --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd 加上你的參數

mysqli 過程、對象方式都支持

mysqli提供的三個類:
   1、mysqli 和連接相關的
   2、MySQLi_Result 處理結果集
   3、mysqli_stmt 預處理類

#設置字元集
set_charset

#獲取字元集
character_set_name

獲取資料庫對象

複製代碼
//創建mysqli對象方式 1
//屏蔽連接產生的錯誤
$mysqli = new mysqli('127.0.0.1', 'root', '', 'test');

//只能用函數來判斷是否連接成功
if(mysqli_connect_errno())
{
    echo mysqli_connect_error();
}

//創建mysqli對象方式 2 可以設置一些參數
$mysqli = mysqli_init();
$mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 2);//設置超時時間
$mysqli->real_connect('127.0.0.1', 'root', '', 'test'); 
複製代碼

query:失敗返回false,select成功返回結果集對象,其他返回true 非false,意味著sql執行成功了

無結果集示例

複製代碼
$mysqli = mysqli_init();
$mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 2);//設置超時時間
$mysqli->real_connect('127.0.0.1', 'root', '', 'test');

$sql = "insert into limove(`name`, `order`) values('aa', 11)";
$rst = $mysqli->query($sql);

$sql = "delete from limove where id = 221";
$rst = $mysqli->query($sql);

if($rst === false)
{
    ee($mysqli->errno);
    ee($mysqli->error);
}

#影響條數
ee($mysqli->affected_rows);
#插入的id
ee($mysqli->insert_id);

ee($mysqli);
複製代碼

 

有結果集

 

複製代碼
$mysqli = mysqli_init();
$mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 2);//設置超時時間
$mysqli->real_connect('127.0.0.1', 'root', '', 'test');

$sql = "select * from limove as limove_as";

$result = $mysqli->query($sql);
if($result === false)
{
    ee($mysqli->errno);
    ee($mysqli->error);
}

#行數
ee($result->num_rows);

#列數
ee($result->field_count);

#欄位個數
ee($result->field_count);

#獲取所有欄位的信息
$field_arr = $result->fetch_fields();

#移動欄位的指針
// $result->field_seek(1);

#依次獲取欄位的信息
while($field = $result->fetch_field())
{
    ee($field);
}

#移動記錄指針
$result->data_seek(1);

#一次獲取所有數據
$data = $result->fetch_all(MYSQLI_ASSOC);

#關聯數組方式獲取結果集
$data = array();

$result->data_seek(0); #重置指針到起始
while($row = $result->fetch_assoc())
{
    $data[] = $row;
}

ee($data);


$result->free();
$mysqli->close();
複製代碼

一次 執行多條語句 multiquery (不推薦使用)

  無結果集,此時 affected_rows 只能獲取到最後的那條影響的條數

複製代碼
$mysqli = mysqli_init();
$mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 2);//設置超時時間
$mysqli->real_connect('127.0.0.1', 'root', '', 'test');


$sql_arr = array(
    'insert into limove(id,`name`, `order`) values(null, 1, 2)',        
    'insert into limove(id,`name`, `order`) values(null, 1, 222)',        
    'delete from limove where `order` = 2',        
);

$sql = implode(';', $sql_arr);

$result = $mysqli->multi_query($sql);
if($result === false)
{
    ee($mysqli->errno);
    ee($mysqli->error);
}

$mysqli->close();
複製代碼

 

有結果集

複製代碼
$mysqli = mysqli_init();
$mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 2);//設置超時時間
$mysqli->real_connect('127.0.0.1', 'root', '', 'test');

$sql_arr = array(
    'show tables',        
    'desc select * from limove',        
    'show create table limove',        
);

$sql = implode(';', $sql_arr);

$rst = $mysqli->multi_query($sql);

if($rst === false)
{
    ee($mysqli->errno);
    ee($mysqli->error);
}

do{
    $result = $mysqli->store_result();#獲取當前游標所在的結果集
    
    $data = $result->fetch_all();
    
    ee($data);
    
}while($mysqli->next_result());#游標移動到下一個結果集

$mysqli->close();
複製代碼

 

事務處理:

複製代碼
    $mysqli=new mysqli("localhost", "root", "123456", "xsphpdb");

    //事務處理
    $mysqli->autocommit(0);

    $error=true;

    $price=50;

    $sql="update zh set ye=ye-{$price} where name='zhangsan'";
    
    $result=$mysqli->query($sql);

    if(!$result){
        $error=false;
        echo "從張三轉出失敗
"; }else{ if($mysqli->affected_rows==0){ $error=false; echo "張三的錢沒有變化"; }else{ echo "從張三賬號中轉出成功!
"; } } $sql="update zh set ye=ye+{$price} where name='lisi1'"; $result=$mysqli->query($sql); if(!$result){ $error=false; echo "從李四轉入失敗
"; }else{ if($mysqli->affected_rows==0){ $error=false; echo "李四的錢沒有變化"; }else{ echo "向李四賬號中轉入成功!
"; } } if($error){ echo "轉賬成功!"; $mysqli->commit(); }else{ echo "轉賬失敗!"; $mysqli->rollback(); } $mysqli->autocommit(1); $mysqli->close();
複製代碼

 

mysqli_stmt:mysqli預處理類(推薦):表示了準備好的一個語句,伺服器端只編譯一次sql
用mysqli和mysqli_result可以實現同樣的功能
優點:效率高,適用於語句相同只是數據不同的情況 ,可以阻止sql註入的產生

 

 mysqli_stmt示例:非select語句

複製代碼
require  'fns.php';

//創建mysqli對象方式 
$mysqli = @new mysqli('127.0.0.1', 'root', '', 'test');

//只能用函數來判斷是否連接成功
if(mysqli_connect_errno())
{
    echo mysqli_connect_error();
    die;
}

$mysqli->set_charset('utf8');

$sql = "insert into limove values(?, ?, ?)"; //語句一樣值不相同情況



//mysqli中有直接的方法可用
$stmt = $mysqli->prepare($sql);

//綁定參數
$stmt->bind_param('iss', $id, $name, $order);

for($i=0;$i<5;$i++){
    $id = 0;
    $name = 'name';
    $order = mt_rand(1, 1000);
    $stmt->execute();

}

//最後id
ee($stmt->insert_id);

//影響的行數 註:最後一條執行的
ee($stmt->affected_rows);

//錯誤號
ee($stmt->errno);

//錯誤信息
ee($stmt->error);

//stmt對象中可以看到更多的信息
ee($stmt);

eee($mysqli);
複製代碼

 

  mysqli_stmt示例:select語句 1 

複製代碼
require  'fns.php';

//創建mysqli對象方式 
$mysqli = @new mysqli('127.0.0.1', 'root', '', 'test');

//只能用函數來判斷是否連接成功
if(mysqli_connect_errno())
{
    echo mysqli_connect_error();
    die;
}

$mysqli->set_charset('utf8');

$sql = "select * from limove where id							
		

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 題目要求:用戶隨機輸入字母及數字組成的字元串,當用戶連續輸入字元串‘hello’時,程式結束用戶輸入,並分別顯示用戶輸入的字母及數字的數目。 代碼: 題目解析:首先這道題目要求用戶輸入字元串”hello“時結束輸入,不如分別判斷這五個字母,其次需要程式自動結束輸入,我們就需要用Console.Rea ...
  • 1.VirtrualBox安裝Centos6.8 minimal VirtrualBox新建個虛擬機配置好記憶體以及硬碟大小,安裝即可; 網路方式是 NAT(預設)和橋接方式來實現,最好在安裝前設置好,NAT主要是連外網,橋接可通過區域網IP訪問; 設置-網路-網卡1(NAT)預設已經設置好了,再點開 ...
  • 一年之前,我做夢也想不到會來這裡寫技術總結。誤打誤撞來到了上海西南某高校,成為了文科專業的工科男,現在每天除了膜ha,就是惡補CS。導師是做計算語言學的,所以當務之急就是先自學電腦自然語言處理,打好底子準備做科研(認真臉)。 進入正題,從圖書館找了本“Natural Language Proces ...
  • More is better Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 327680/102400 K (Java/Others)Total Submission(s): 24825 Accepted Submission(s): 89 ...
  • 一、SpringAOP: ⒈AOP:Aspect Oriented Programming 面向切麵編程, 實現的是核心業務和非核心業務之間的的分離,讓核心類只做核心業務,代理類只做非核心業務。 ⒉目的: ⑴、把核心業務和非核心業務進行分離 ⑵、把多個非核心業務處理(點)變成一個切麵(之前的非核心業 ...
  • cd命令是linux實際使用當中另一個非常重要的命令,本文就為大家介紹下Linux中cd命令的用法。 更多Linux命令詳情請看:Linux命令速查手冊 Linux cd命令用於切換當前工作目錄至 dirName(目錄參數)。 其中 dirName 表示法可為絕對路徑或相對路徑。若目錄名稱省略,則變 ...
  • 在我們安裝PHP模塊時,有時需要註意PHP編譯的版本,下麵講解下PHP中VC6、VC9、TS、NTS版本的區別與用法詳解,介紹php的兩種執行方式。 1. VC6與VC9的區別:VC6版本是使用Visual Studio 6編譯器編譯的,如果你的PHP是用Apache來架設的,那你就選擇VC6版本。 ...
  • \_\_init\_\_.py 文件的作用是將文件夾變為一個Python模塊,Python 中的每個模塊的包中,都有\_\_init\_\_.py 文件。 通常\_\_init\_\_.py 文件為空,但是我們還可以為它增加其他的功能。我們在導入一個包時,實際上是導入了它的\_\_init\_\_. ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...