PHP Conference Japan 2024

SQLite3Result::columnType

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

SQLite3Result::columnType返回第 n 列的类型

描述

public SQLite3Result::columnType(int $column): int|false

返回由 column 标识的列的类型。

参数

column

列的数字索引(从 0 开始)。

返回值

返回由 column 标识的列的数据类型索引(SQLITE3_INTEGERSQLITE3_FLOATSQLITE3_TEXTSQLITE3_BLOBSQLITE3_NULL 之一),如果列不存在则返回 false

添加注释

用户贡献的注释 3 条注释

11
phpnotes at carwash dot org
13 年前
此函数从未返回除 5 之外的任何值,表示 SQLITE3_NULL。SQLite 3 没有列类型,它有列亲和性。同一表的不同行(以及 SELECT 生成的行)可以保存不同类型的值。因此,此 API 无法返回任何有用的内容,并且该方法似乎正在使用 SQLITE3_NULL 作为占位符。

该函数毫无用处,应该在将来的版本中将其删除或标记为已弃用,以免给任何程序员造成列返回的值有用的错误印象。
3
hairbysubaru at gmail dot com
8 年前
jean-marc 是正确的。SQLite 根据返回的记录集动态确定列类型。
4
jean-marc at paratte dot ch
10 年前
要查找列的类型,您需要“查询”SQL 语句,“fetchArray”第一行,然后提取每列的名称和类型。

示例

function _sqlite_fetch_all( $db, $sql ) {

$sqlite = new SQLite3( $db);

if( $sqlite->lastErrorCode() ) return;

$result = $sqlite->query( $sql );

$result->fetchArray( SQLITE3_NUM );
$fieldnames = [];
$fieldtypes = [];
for( $colnum=0; $colnum<$result->numColumns(); $colnum++) {
$fieldnames[] = $result->columnName($colnum);
$fieldtypes[] = $result->columnType($colnum);
}
$result->reset();

while( $row = $result->fetchArray( SQLITE3_NUM ) ) {

for ($colnum=0; $colnum<count($row); $colnum++) {
$col = &$row[$colnum];
if (isset($fieldtype_encode_binary[$fieldtypes[$colnum]])) $col = $fieldtype_encode_binary[$fieldtypes[$colnum]]( $col );
}
unset($col);
if ($resulttype == SQLITE3_ASSOC) $row = array_combine( $fieldnames, $row );
$rows[] = $row;
}

$result->finalize();

$sqlite->close();

return $rows;
}

备注 1:在任何“fetchArray”之前,列的类型为 SQLITE3_NULL,在最后一行获取后为“false”。

备注 2:SQLITE3_INTEGER、SQLITE3_FLOAT、SQLITE3_TEXT、SQLITE3_BLOB、SQLITE3_NULL 的实际值为 1、2、3、4、5。
To Top