-
PHP操作Postgresql封装类与应用完整实例
这篇文章主要介绍了PHP操作Postgresql封装类,结合实例形式分析了php针对Postgresql数据库常见的连接、查询、统计等操作封装技巧与使用方法,需要的朋友可以参考下
本文实例讲述了PHP操作Postgresql封装类与应用。分享给大家供大家参考,具体如下:
这个类封装了一些常用的函数,原帖里面还有事务处理的内容,以后再学习吧。
类文件定义:
- <?php
- class pgsql {
- private $linkid; // PostgreSQL连接标识符
- private $host; // PostgreSQL服务器主机
- private $port; // PostgreSQL服务器主机端口
- private $user; // PostgreSQL用户
- private $passwd; // PostgreSQL密码
- private $db; // Postgresql数据库
- private $result; // 查询的结果
- private $querycount; // 已执行的查询总数
- /* 类构造函数,用来初始化$host、$user、$passwd和$db字段。 */
- function __construct($host, $port ,$db, $user, $passwd) {
- $this->host = $host;
- $this->port = $port;
- $this->user = $user;
- $this->passwd = $passwd;
- $this->db = $db;
- }
- /* 连接Postgresql数据库 */
- function connect(){
- try{
- $this->linkid = @pg_connect("host=$this->host port=$this->port dbname=$this->db
- user=$this->user password=$this->passwd");
- if (! $this->linkid)
- throw new Exception("Could not connect to PostgreSQL server.");
- }
- catch (Exception $e) {
- die($e->getMessage());
- }
- }
- /* 执行数据库查询。 */
- function query($query){
- try{
- $this->result = @pg_query($this->linkid,$query);
- if(! $this->result)
- throw new Exception("The database query failed.");
- }
- catch (Exception $e){
- echo $e->getMessage();
- }
- $this->querycount++;
- return $this->result;
- }
- /* 确定受查询所影响的行的总计。 */
- function affectedRows(){
- $count = @pg_affected_rows($this->linkid);
- return $count;
- }
- /* 确定查询返回的行的总计。 */
- function numRows(){
- $count = @pg_num_rows($this->result);
- return $count;
- }
- /* 将查询的结果行作为一个对象返回。 */
- function fetchObject(){
- $row = @pg_fetch_object($this->result);
- return $row;
- }
- /* 将查询的结果行作为一个索引数组返回。 */
- function fetchRow(){
- $row = @pg_fetch_row($this->result);
- return $row;
- }
- /* 将查询的结果行作为一个关联数组返回。 */
- function fetchArray(){
- $row = @pg_fetch_array($this->result);
- return $row;
- }
- /* 返回在这个对象的生存期内执行的查询总数。这不是必须的,但是您也许会感兴趣。 */
- function numQueries(){
- return $this->querycount;
- }
- }
- ?>
测试的php一并放出,另外测试了下局域网内的另一台postgresql服务器,感觉查询速度还是很快的,查询postgregis数据也是杠杠滴。
- <?php
- include 'PGDB.php';
- $PG = new pgsql("192.168.1.167", "5432", "postgis", "postgres", "post");
- $PG->connect();
- if(!$PG)
- {
- $db_error = "无法连接到PostGreSQL数据库!";
- echo $db_error;
- }
- else
- {
- echo "成功连接!";
- $query = "select name from ex where gid = 2";
- $result = $PG->query($query);
- $row = $PG->fetchRow();
- echo $row[0];
- }
- ?>
出处:http://www.phpfensi.com/php/20210912/18010.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式