欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP PDO和消息隊列的個人理解與應(yīng)用實例分析

 更新時間:2019年11月25日 09:59:30   作者:循環(huán)源圈  
這篇文章主要介紹了PHP PDO和消息隊列的個人理解與應(yīng)用,結(jié)合實例形式分析了PHP pdo與消息隊列相關(guān)配置、使用方法及操作注意事項,需要的朋友可以參考下

本文實例講述了PHP PDO和消息隊列的個人理解與應(yīng)用。分享給大家供大家參考,具體如下:

什么是消息隊列,百度百科說,···消息隊列····是在消息的傳輸過程中保存消息的容器。

看著網(wǎng)上林林總總的文章,都說是為了應(yīng)對高并發(fā),處理數(shù)據(jù)量超級大的一種數(shù)據(jù)容器,也可以說是利用各種方式,先把數(shù)據(jù)存儲在一個···容器···中,然后,再慢慢從這個容器中獲取數(shù)據(jù),實現(xiàn)·····異步操作數(shù)據(jù)庫·····的方式,以便降低數(shù)據(jù)庫的壓力。

不管消息隊列是什么,個人姑且認(rèn)為它就是一種存儲數(shù)據(jù)的···容器···,就這么簡單明了,呵呵,因為本人對消息隊列這東西研究的比較膚淺。

不過,在這里,我還是要賣弄一下一個個人的小實驗代碼,呵呵,假若下面的東西與消息隊列相離太遠(yuǎn),那么請看官可別見怪哦,因為我上面已經(jīng)聲明的很清楚了,本人對這東西還是不甚了解,只不過是工作之余賣弄一下‘文采'而已,所以,假如真有誤解消息隊列這個東西,我只能說聲,請你指正我的錯誤,讓筆者迷途知返。

先給出連接mysql數(shù)據(jù)庫配置文件mysql.ini的內(nèi)容:

[database]
driver = mysql
host = 127.0.0.1
port = 3306
dbname = mysql
username = root
password = 1234
[options]
PDO::MYSQL_ATTR_INIT_COMMAND = set names utf8

數(shù)據(jù)表文件queue.sql的內(nèi)容:

-- 消息隊列測試
-- 商品表
create table goods(
id int unsigned primary key auto_increment,
goodsname varchar(40) not null comment '商品名',
price decimal(9,2) not null comment '價格',
category_id tinyint unsigned not null comment '商品類別id',
sort tinyint comment '商品排序',
description varchar(255) comment '商品描述',
remark varchar(255) comment '備注'
)engine InnoDB default charset=utf8;
insert into goods values(default,'iPhone5s',5999,1,1,'美國入口貴重電子產(chǎn)品','請多多銷售'),(default,'宏基手提電腦1',4888,3,1,'價格劃算好電腦',null),(default,'f-30絨衣',200,2,1,'以純白色厚皮羽絨服',null),(default,'n-100鞋子',300,4,1,'Nick品牌',null);

下面是簡單的消息隊列實現(xiàn)PDO商品入庫的代碼:

鄭重提醒:請認(rèn)真看我的注釋,請認(rèn)真看我的注釋,請認(rèn)真看我的注釋。重要的信息要說三遍,呵呵!

<?php
namespace Home;
header('content-type:text/html;charset=utf-8;');
//引入PDO類
use \PDO;
use \PDOStatement;
use \PDOException;
/*簡單消息隊列*/
class Queue{
  //容器可以是私有,最好是公有
  static public $container=array();
  //把PDO對象存放到屬性中是為了跨方法使用
  static private $pdo;
  //構(gòu)造函數(shù)實現(xiàn)初始化PDO連接數(shù)據(jù)庫
  public function __construct($file = './mysql.ini'){//mysql數(shù)據(jù)庫的配置文件,./mysql.ini與這個類是同一個目錄
    //parse_ini_file函數(shù)作用,解析并獲取ini文件的參數(shù),加true是二維數(shù)組
    $dbini    = parse_ini_file($file,true);
    $driver    = $dbini['database']['driver'];
    //這里的數(shù)據(jù)庫是mysql的總數(shù)據(jù)庫
    $dbname    = $dbini['database']['dbname'];
    $host    = $dbini['database']['host'];
    $port    = $dbini['database']['port'];
    //構(gòu)造PDO連接數(shù)據(jù)庫的第一個參數(shù),這個參數(shù)這么設(shè)置純屬是PDO類的語法,不懂的可以百度一下,這里就不做詳解了
    $dsn = $driver.':'.'dbname='.$dbname.';host='.$host.';port='.$port;
    //其他連接數(shù)據(jù)庫參數(shù)
    $username  = $dbini['database']['username'];
    $password  = $dbini['database']['password'];
    $options  = $dbini['options'];//初始化設(shè)置PDO選項
    try{
      self::$pdo = new PDO($dsn,$username,$password,$options);
      //設(shè)置PDO屬性。拋出錯誤報告
      self::$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
      try{
        //選擇商品數(shù)據(jù)表所在的數(shù)據(jù)庫
        self::$pdo->exec('use queue');
      }catch(PDOException $e){
        echo $e->getMessage();
      }
    }catch(PDOException $e){
      echo $e->getMessage();
    }
  }
  /*
  *入列
  *$data數(shù)組
  *成功返回1,失敗返回false,或者null
  */
  public function _unshift($data =array()){
    if(!is_array($data) || empty($data)){return false;}
    $sql = 'default';
    foreach($data as $k=>$v){
      $sql .= ',"'.$v.'"';
    }
    //把$data轉(zhuǎn)為sql語句,添加到隊列容器contain中
    $sql = 'insert into goods values('.$sql.')';
    return @array_unshift(self::$container,$sql);
  }
  /*
  *出列
  *成功返回最后插入的數(shù)據(jù)id
  *失敗返回失敗信息
  */
  private static function _pop(){
    try{//獲取尾部的sql語句,出列
      $sql = array_pop(self::$container);
      self::$pdo->exec($sql);
      //把剩余的容器值賦給中間變量
      $middle = self::$container;
      //判斷中間變量是否為空,不為空則繼續(xù)獲取容器尾部的數(shù)據(jù),繼續(xù)出列
      while($middle){
        $sql = array_pop($middle);
        self::$pdo->exec($sql);
        //把數(shù)據(jù)再轉(zhuǎn)給容器,也就是轉(zhuǎn)給while循環(huán)外面的$middle,這樣才能實現(xiàn)循環(huán),讓容器里面的數(shù)據(jù)全部出列,插入到數(shù)據(jù)庫中
        self::$container = $middle;
      }
      //返回的是,最后插入的id,失敗是null
      return self::$pdo->lastInsertId();
      }catch(PDOException $e){
        return $e->getMessage();
      }
  }
  //析構(gòu)函數(shù),對象回收時調(diào)用,通過它實現(xiàn)自動讓容器數(shù)據(jù)入庫
  public function __destruct(){
    //當(dāng)對象被回收時,判斷容器是否存在消息,假如存在,則調(diào)用_pop方法,把消息出列
    if(self::$container){
      self::_pop();
    }
  }
}

下面是同一級目錄下調(diào)用這個類的文件的內(nèi)容,當(dāng)然,你也可以在上面那個queue類的下面調(diào)用_unshift方法實現(xiàn)消息隊列的操作

<?php
include './queue.php';
use Home\Queue;//引入命名空間的Queue類
$ob = new Queue;
//消息入列
$ob->_unshift(array('goodsname'=>'vivo手機(jī)8888','price'=>1120,'category_id'=>1,'sort'=>1,'description'=>'vivo品牌','remark'=>'好用'));
$ob->_unshift(array('goodsname'=>'小米手機(jī)888','price'=>1998,'category_id'=>1,'sort'=>1,'description'=>'小米品牌手機(jī)','remark'=>'國產(chǎn)好貨'));
//之所以打印出來,完成是為了看看效果,至于,有沒有實現(xiàn)商品入庫,你得去看看你的數(shù)據(jù)庫了,呵呵
var_dump(Queue::$container);

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫技巧總結(jié)》、《php+mysqli數(shù)據(jù)庫程序設(shè)計技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總

希望本文所述對大家PHP程序設(shè)計有所幫助。

相關(guān)文章

  • 微信公眾號點擊菜單即可打開并登錄微站的實現(xiàn)方法

    微信公眾號點擊菜單即可打開并登錄微站的實現(xiàn)方法

    這篇文章主要介紹了微信公眾號點擊菜單即可打開并登錄微站的實現(xiàn)方法,以實例形式對回調(diào)、菜單及參數(shù)的處理等具體實現(xiàn)步驟與功能代碼都做了較為詳細(xì)的描述,對于微信公眾號的開發(fā)來說具有很好的參考借鑒價值,需要的朋友可以參考下
    2014-11-11
  • php+mysql查詢實現(xiàn)無限下級分類樹輸出示例

    php+mysql查詢實現(xiàn)無限下級分類樹輸出示例

    這篇文章主要介紹了php+mysql查詢實現(xiàn)無限下級分類樹輸出,結(jié)合實例形式分析了php+MySQL查詢實現(xiàn)的樹狀分類輸出功能,涉及php數(shù)據(jù)庫查詢與數(shù)組遍歷等相關(guān)操作技巧,需要的朋友可以參考下
    2016-10-10
  • PHP中判斷文件存在使用is_file還是file_exists?

    PHP中判斷文件存在使用is_file還是file_exists?

    這篇文章主要介紹了PHP中判斷文件存在使用is_file還是file_exists?本文使用一個測試程序證明使用哪個函數(shù)比較好,需要的朋友可以參考下
    2015-04-04
  • PHP簡單獲取及判斷提交來源的方法

    PHP簡單獲取及判斷提交來源的方法

    這篇文章主要介紹了PHP簡單獲取及判斷提交來源的方法,涉及PHP中$_SERVER及字符串操作的使用技巧,需要的朋友可以參考下
    2016-04-04
  • PHP獲取時間戳等相關(guān)函數(shù)匯總

    PHP獲取時間戳等相關(guān)函數(shù)匯總

    PHP是一種廣泛使用的服務(wù)器端腳本語言,具有豐富的時間戳相關(guān)函數(shù)。本文介紹了PHP中獲取時間戳的常用函數(shù),包括time()、strtotime()、date()等,并提供了使用示例。同時,還介紹了PHP中其他與時間相關(guān)的函數(shù),如mktime()、microtime()等。
    2023-06-06
  • php之CodeIgniter學(xué)習(xí)筆記

    php之CodeIgniter學(xué)習(xí)筆記

    本篇文章是對php中的CodeIgniter進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • PHP JSAPI調(diào)支付API實現(xiàn)微信支付功能詳解

    PHP JSAPI調(diào)支付API實現(xiàn)微信支付功能詳解

    本人最近做了微信支付開發(fā),是第一次接觸,其中走了很多彎路,遇到的問題也很多。為了讓和我一樣的新人不再遇到類似的問題,我把我的開發(fā)步驟和問題寫出來以供參考,這篇文章主要介紹了PHP JSAPI調(diào)支付API實現(xiàn)微信支付功能
    2022-11-11
  • php基于curl實現(xiàn)的股票信息查詢類實例

    php基于curl實現(xiàn)的股票信息查詢類實例

    這篇文章主要介紹了php基于curl實現(xiàn)的股票信息查詢類,結(jié)合完整實例形式分析了php使用curl調(diào)用API接口實現(xiàn)股票信息查詢功能的相關(guān)操作技巧,需要的朋友可以參考下
    2016-11-11
  • php實現(xiàn)用戶在線時間統(tǒng)計詳解

    php實現(xiàn)用戶在線時間統(tǒng)計詳解

    php實現(xiàn)用戶在線時間統(tǒng)計詳解,需要的朋友可以參考下。
    2011-10-10
  • php讀取txt文件并將數(shù)據(jù)插入到數(shù)據(jù)庫

    php讀取txt文件并將數(shù)據(jù)插入到數(shù)據(jù)庫

    這篇文章主要介紹了php讀取txt文件并將數(shù)據(jù)插入到數(shù)據(jù)庫的方法和示例代碼,小文件大家可以參考第一種,大文件導(dǎo)入的話請參考第二種。
    2016-02-02

最新評論