本文实例讲述了PHP PDO和消息队列的个人理解与应用。分享给大家供大家参考,具体如下:
什么是消息队列,百度百科说,···消息队列····是在消息的传输过程中保存消息的容器。
看着网上林林总总的文章,都说是为了应对高并发,处理数据量超级大的一种数据容器,也可以说是利用各种方式,先把数据存储在一个···容器···中,然后,再慢慢从这个容器中获取数据,实现·····异步操作数据库·····的方式,以便降低数据库的压力。
不管消息队列是什么,个人姑且认为它就是一种存储数据的···容器···,就这么简单明了,呵呵,因为本人对消息队列这东西研究的比较肤浅。
不过,在这里,我还是要卖弄一下一个个人的小实验代码,呵呵,假若下面的东西与消息队列相离太远,那么请看官可别见怪哦,因为我上面已经声明的很清楚了,本人对这东西还是不甚了解,只不过是工作之余卖弄一下‘文采'而已,所以,假如真有误解消息队列这个东西,我只能说声,请你指正我的错误,让笔者迷途知返。
先给出连接mysql数据库配置文件mysql.ini的内容:
1
2
3
4
5
6
7
8
9
|
[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 |
数据表文件queue.sql的内容:
1
2
3
4
5
6
7
8
9
10
11
12
|
-- 消息队列测试 -- 商品表 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, '美国入口贵重电子产品' , '请多多销售' ),( default , '宏基手提电脑1' ,4888,3,1, '价格划算好电脑' , null ),( default , 'f-30绒衣' ,200,2,1, '以纯白色厚皮羽绒服' , null ),( default , 'n-100鞋子' ,300,4,1, 'Nick品牌' , null ); |
下面是简单的消息队列实现PDO商品入库的代码:
郑重提醒:请认真看我的注释,请认真看我的注释,请认真看我的注释。重要的信息要说三遍,呵呵!
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
|
<?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 ; //构造函数实现初始化PDO连接数据库 public function __construct( $file = './mysql.ini' ){ //mysql数据库的配置文件,./mysql.ini与这个类是同一个目录 //parse_ini_file函数作用,解析并获取ini文件的参数,加true是二维数组 $dbini = parse_ini_file ( $file ,true); $driver = $dbini [ 'database' ][ 'driver' ]; //这里的数据库是mysql的总数据库 $dbname = $dbini [ 'database' ][ 'dbname' ]; $host = $dbini [ 'database' ][ 'host' ]; $port = $dbini [ 'database' ][ 'port' ]; //构造PDO连接数据库的第一个参数,这个参数这么设置纯属是PDO类的语法,不懂的可以百度一下,这里就不做详解了 $dsn = $driver . ':' . 'dbname=' . $dbname . ';host=' . $host . ';port=' . $port ; //其他连接数据库参数 $username = $dbini [ 'database' ][ 'username' ]; $password = $dbini [ 'database' ][ 'password' ]; $options = $dbini [ 'options' ]; //初始化设置PDO选项 try { self:: $pdo = new PDO( $dsn , $username , $password , $options ); //设置PDO属性。抛出错误报告 self:: $pdo ->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); try { //选择商品数据表所在的数据库 self:: $pdo -> exec ( 'use queue' ); } catch (PDOException $e ){ echo $e ->getMessage(); } } catch (PDOException $e ){ echo $e ->getMessage(); } } /* *入列 *$data数组 *成功返回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转为sql语句,添加到队列容器contain中 $sql = 'insert into goods values(' . $sql . ')' ; return @ array_unshift (self:: $container , $sql ); } /* *出列 *成功返回最后插入的数据id *失败返回失败信息 */ private static function _pop(){ try { //获取尾部的sql语句,出列 $sql = array_pop (self:: $container ); self:: $pdo -> exec ( $sql ); //把剩余的容器值赋给中间变量 $middle = self:: $container ; //判断中间变量是否为空,不为空则继续获取容器尾部的数据,继续出列 while ( $middle ){ $sql = array_pop ( $middle ); self:: $pdo -> exec ( $sql ); //把数据再转给容器,也就是转给while循环外面的$middle,这样才能实现循环,让容器里面的数据全部出列,插入到数据库中 self:: $container = $middle ; } //返回的是,最后插入的id,失败是null return self:: $pdo ->lastInsertId(); } catch (PDOException $e ){ return $e ->getMessage(); } } //析构函数,对象回收时调用,通过它实现自动让容器数据入库 public function __destruct(){ //当对象被回收时,判断容器是否存在消息,假如存在,则调用_pop方法,把消息出列 if (self:: $container ){ self::_pop(); } } } |
下面是同一级目录下调用这个类的文件的内容,当然,你也可以在上面那个queue类的下面调用_unshift方法实现消息队列的操作
1
2
3
4
5
6
7
8
9
|
<?php include './queue.php' ; use Home\Queue; //引入命名空间的Queue类 $ob = new Queue; //消息入列 $ob ->_unshift( array ( 'goodsname' => 'vivo手机8888' , 'price' =>1120, 'category_id' =>1, 'sort' =>1, 'description' => 'vivo品牌' , 'remark' => '好用' )); $ob ->_unshift( array ( 'goodsname' => '小米手机888' , 'price' =>1998, 'category_id' =>1, 'sort' =>1, 'description' => '小米品牌手机' , 'remark' => '国产好货' )); //之所以打印出来,完成是为了看看效果,至于,有没有实现商品入库,你得去看看你的数据库了,呵呵 var_dump(Queue:: $container ); |
希望本文所述对大家PHP程序设计有所帮助。
原文链接:https://www.cnblogs.com/loveyoume/p/6107239.html