PHP Conference Japan 2024

SQLite3::createCollation

(PHP 5 >= 5.3.11, PHP 7, PHP 8)

SQLite3::createCollation注册一个 PHP 函数作为 SQL 排序函数

描述

public SQLite3::createCollation(string $name, callable $callback): bool

注册一个 PHP 函数或用户定义函数,在 SQL 语句中用作排序函数。

参数

name

要创建或重新定义的 SQL 排序函数的名称

callback

作为回调应用的 PHP 函数或用户定义函数的名称,定义排序的行为。它应该接受两个值并像 strcmp() 一样返回,即如果第一个字符串在第二个字符串之前排序、之后排序或等于第二个字符串,它应该分别返回 -1、1 或 0。

此函数需要定义为

collation(mixed $value1, mixed $value2): int

返回值

成功时返回 true,失败时返回 false

示例

示例 #1 SQLite3::createCollation() 示例

将 PHP 函数 strnatcmp() 注册为 SQLite3 数据库中的排序顺序。

<?php

$db
= new SQLite3(":memory:");
$db->exec("CREATE TABLE test (col1 string)");
$db->exec("INSERT INTO test VALUES ('a1')");
$db->exec("INSERT INTO test VALUES ('a10')");
$db->exec("INSERT INTO test VALUES ('a2')");

$db->createCollation('NATURAL_CMP', 'strnatcmp');

$defaultSort = $db->query("SELECT col1 FROM test ORDER BY col1");
$naturalSort = $db->query("SELECT col1 FROM test ORDER BY col1 COLLATE NATURAL_CMP");

echo
"default:\n";
while (
$row = $defaultSort->fetchArray()){
echo
$row['col1'], "\n";
}

echo
"\nnatural:\n";
while (
$row = $naturalSort->fetchArray()){
echo
$row['col1'], "\n";
}

$db->close();

?>

以上示例将输出

default:
a1
a10
a2

natural:
a1
a2
a10

添加注释

用户贡献的注释

此页面没有用户贡献的注释。
To Top