mysql drizzle_MySQL一派添“轻功”Drizzle+PHP抢先体验(2)

2023-10-13 00:20

本文主要是介绍mysql drizzle_MySQL一派添“轻功”Drizzle+PHP抢先体验(2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Drizzle PHP入门

通过Drizzle PHP扩展,可以在PHP里获得全面的API来操纵Drizzle数据库。这一扩展目前由Eric Day, James Luedke以及其它人员维护,可以遵照PHP许可证从PECL里免费获得。虽然这个扩展目前还处于Beta阶段,但它已经涵盖了PHP应用程序中可能涉及到的各种常见任务。

要开始使用了Drizzle PHP扩展(v0.4.0 ),用PECL自动安装程序就可以了,如下:shell> pecl install drizzle-beta

或者,你也可以下载它的源代码,并将其编译成一个可加载的PHP模块,如下:shell> tar -xzvf drizzle-0.4.0.tar.gz

shell> cd drizzle-0.4.0

shell> phpize

shell> ./configure

shell> make

shell> make install

至此,在你的PHP模块目录下应该就有了名为drizzle.so的一个可加载模块。在php.ini配置文件里启用此扩展,重新启动Web服务器,并用phpinfo()函数检查这一扩展是否已经启用:

19a3d98d6a40a6c902e60e6844d2f1bd.png

小提示

下面的例子演示了用Drizzle PHP扩展执行SELECT语句查询数据库服务器,并将查询结果以HTML表格的格式输出。

table,tr,td {

border: solid 1px black;

border-collapse: collapse;

padding: 5px;

}

List Items

// set connection parameters

$host='localhost';

$port=4427;

$user='root';

$pass='guessme';

$db='test';

// create drizzle object

$drizzle=drizzle_create();

// connect to database server

$conn=drizzle_con_add_tcp($drizzle, $host, $port, $user, $pass, $db, 0)

or die('ERROR: ' . drizzle_error($drizzle));

// execute query

$sql='SELECT ItemDesc, ItemQty FROM items';

$result= @drizzle_query($conn, $sql)

or die ('ERROR: ' . drizzle_con_error($conn));

// buffer result set

drizzle_result_buffer($result)

or die('ERROR: ' . drizzle_con_error($conn));

// check number of rows in result set and print

if (drizzle_result_row_count($result)) {

echo '

while (($row=drizzle_row_next($result))) {

echo '

';

echo '

' . $row[0] . '';

echo '

' . $row[1] . '';

echo '

';

}

echo '

';

} else {

echo 'No records found';

}

// free result set

drizzle_result_free($result);

// close connection

drizzle_con_close($conn);

?>

该脚本一开始就通过指定必要的信息来建立与数据库服务器的一个连接。这些信息包括服务器名称,服务器端口,用户名和密码,以及要查询的数据库名称。这些值都是用普通的PHP变量保存的。drizzle_create()函数会初始化一个Drizzle对象,这些连接时需要的参数则是通过drizzle_con_add_tcp()函数添加进去的。这个函数返回一个连接标识符,用于接下来与数据库服务器间的通信。

下一步是创建查询语句并执行。这是通过drizzle_query()函数实现的,它需要两个参数,一个是查询语句,另一个是连接标识符。drizzle_query()函数的返回值是一个结果对象,代表着这次查询的结果。如果你愿意的话,可以使用drizzle_result_buffer()函数缓存这个结果集;不过要注意,如果查询返回的结果集很大的话,这对内存的占用也是非常明显的。

drizzle_result_row_count()函数返回缓存的结果集中记录的条数。这些记录可以用drizzle_row_next()函数检索,它能在结果集中迭代,并且以数组的形式获取每条结果。然后就可以通过数组符号访问各个字段了。

当你处理完每个结果集之后,最好用drizzle_result_free()函数释放它所用的内存。若要彻底清理干净,则可使用drizzle_con_close()函数断开与Drizzle服务器的连接。

下面这段代码的输出演示:

c73af6d1be1ee07ab8408e77c12c4402.png

使用面向对象

你也可以用面向对象方式使用Drizzle API,之前所用的每个函数都对应于对象的一种方法。请看下面这段代码,它与之前那段是等价的:

table,tr,td {

border: solid 1px black;

border-collapse: collapse;

padding: 5px;

}

List Items

// set connection parameters

$host='localhost';

$port=4427;

$user='root';

$pass='guessme';

$db='test';

// create drizzle object

$drizzle=newdrizzle();

// connect to database server

$conn= $drizzle->addTcp($host, $port, $user, $pass, $db, 0)

or die('ERROR: ' . $drizzle->error());

// execute query

$sql='SELECT ItemDesc, ItemQty FROM items';

$result= @$conn->query($sql)

or die('ERROR: ' . $conn->error());

// buffer result set

$result->buffer()

or die('ERROR: ' . $conn->error());

// check number of rows in result set and print

if ($result->rowCount()) {

echo '

while (($row= $result->rowNext())) {

echo '

';

echo '

' . $row[0] . '';

echo '

' . $row[1] . '';

echo '

';

}

echo '

';

} else {

echo 'No records found';

}

// close connection

$conn->close();

// deinitialize object

unset($drizzle);

?>

在这里,new关键字实例化了一个Drizzle对象,并且向这个对象的addTcp()方法传递了相关的连接信息。由此产生的DrizzleCon对象提供了 query () 方法,可以用来在数据库服务器上执行查询。此外还有DrizzleResult对象也提供了一些方法来执行对结果集的获取、缓存、处理等操作。

如果你仔细研究以上这两个脚本,就会发现它们在函数和方法命名以及代码结构上的许多相似之处。

这篇关于mysql drizzle_MySQL一派添“轻功”Drizzle+PHP抢先体验(2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/199440

相关文章

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据