45-php.mdx 3.6 KB
Newer Older
1
---
2
sidebar_label: PHP
3 4 5 6 7
title: PHP Connector
---

`php-tdengine` 是由社区贡献的 PHP 连接器扩展,还特别支持了 Swoole 协程化。

8
PHP 连接器依赖 TDengine 客户端驱动。
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

项目地址:<https://github.com/Yurunsoft/php-tdengine>

TDengine 服务端或客户端安装后,`taos.h` 位于:

- Linux:`/usr/local/taos/include`
- Windows:`C:\TDengine\include`

TDengine 客户端驱动的动态库位于:

- Linux: `/usr/local/taos/driver/libtaos.so`
- Windows: `C:\TDengine\taos.dll`

## 支持的平台

* Windows、Linux、MacOS

* PHP >= 7.4

* TDengine >= 2.0

* Swoole >= 4.8 (可选)

## 支持的版本

TDengine 客户端驱动的版本号与 TDengine 服务端的版本号是一一对应的强对应关系,建议使用与 TDengine 服务端完全相同的客户端驱动。虽然低版本的客户端驱动在前三段版本号一致(即仅第四段版本号不同)的情况下也能够与高版本的服务端相兼容,但这并非推荐用法。强烈不建议使用高版本的客户端驱动访问低版本的服务端。

## 安装步骤

### 安装 TDengine 客户端驱动

G
gccgdb1234 已提交
40
TDengine 客户端驱动的安装请参考 [安装指南](../#安装步骤)
41 42 43 44 45 46 47 48 49 50 51

### 编译安装 php-tdengine

**下载代码并解压:**

```shell
curl -L -o php-tdengine.tar.gz https://github.com/Yurunsoft/php-tdengine/archive/refs/tags/v1.0.2.tar.gz \
&& mkdir php-tdengine \
&& tar -xzf php-tdengine.tar.gz -C php-tdengine --strip-components=1
```

52
> 版本 `v1.0.2` 可替换为任意更新的版本,可在 [TDengine PHP Connector 发布历史](https://github.com/Yurunsoft/php-tdengine/releases)。
53 54 55 56 57 58 59 60 61 62

**非 Swoole 环境:**

```shell
phpize && ./configure && make -j && make install
```

**手动指定 tdengine 目录:**

```shell
63
phpize && ./configure --with-tdengine-dir=/usr/local/Cellar/tdengine/3.0.0.0 && make -j && make install
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 90 91 92
```

> `--with-tdengine-dir=` 后跟上 tdengine 目录。
> 适用于默认找不到的情况,或者 MacOS 系统用户。

**Swoole 环境:**

```shell
phpize && ./configure --enable-swoole && make -j && make install
```

**启用扩展:**

方法一:在 `php.ini` 中加入 `extension=tdengine`

方法二:运行带参数 `php -dextension=tdengine test.php`

## 示例程序

本节展示了使用客户端驱动访问 TDengine 集群的常见访问方式的示例代码。

> 所有错误都会抛出异常: `TDengine\Exception\TDengineException`

### 建立连接

<details>
<summary>建立连接</summary>

```c
D
dingbo 已提交
93
{{#include docs/examples/php/connect.php}}
94 95 96 97 98 99 100 101 102 103
```

</details>

### 插入数据

<details>
<summary>插入数据</summary>

```c
D
dingbo 已提交
104
{{#include docs/examples/php/insert.php}}
105 106 107 108 109 110 111 112 113 114
```

</details>

### 同步查询

<details>
<summary>同步查询</summary>

```c
D
dingbo 已提交
115
{{#include docs/examples/php/query.php}}
116 117 118 119 120 121 122 123 124 125
```

</details>

### 参数绑定

<details>
<summary>参数绑定</summary>

```c
D
dingbo 已提交
126
{{#include docs/examples/php/insert_stmt.php}}
127 128 129 130 131 132
```

</details>

## 常量

G
gccgdb1234 已提交
133
| 常量 | 说明 |
134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149
| ------------ | ------------ 
| `TDengine\TSDB_DATA_TYPE_NULL` | null |
| `TDengine\TSDB_DATA_TYPE_BOOL` | bool |
| `TDengine\TSDB_DATA_TYPE_TINYINT` | tinyint |
| `TDengine\TSDB_DATA_TYPE_SMALLINT` | smallint |
| `TDengine\TSDB_DATA_TYPE_INT` | int |
| `TDengine\TSDB_DATA_TYPE_BIGINT` | bigint |
| `TDengine\TSDB_DATA_TYPE_FLOAT` | float |
| `TDengine\TSDB_DATA_TYPE_DOUBLE` | double |
| `TDengine\TSDB_DATA_TYPE_BINARY` | binary |
| `TDengine\TSDB_DATA_TYPE_TIMESTAMP` | timestamp |
| `TDengine\TSDB_DATA_TYPE_NCHAR` | nchar |
| `TDengine\TSDB_DATA_TYPE_UTINYINT` | utinyint |
| `TDengine\TSDB_DATA_TYPE_USMALLINT` | usmallint |
| `TDengine\TSDB_DATA_TYPE_UINT` | uint |
| `TDengine\TSDB_DATA_TYPE_UBIGINT` | ubigint |