Web aym.pekori.to

mysqli_fetch_field

(PHP 5)

mysqli_fetch_field

(no version information, might be only in CVS)

result->fetch_field -- 結果セットの次のフィールドを返す

説明

手続き型:

object mysqli_fetch_field ( mysqli_result result )

オブジェクト指向型(メソッド):

class mysqli_result {

object fetch_field ( void )

}

mysqli_fetch_field() は、結果セットから ひとつのカラムの情報をオブジェクトとして返します。この関数を 繰り返しコールすることで、結果セットのすべてのカラムについての情報が 取得可能です。mysqli_fetch_field() は、 フィールドがもう残っていない場合に FALSE を返します。

返り値

フィールド定義情報を含むオブジェクトを返します。もし フィールドの情報が取得できない場合は、FALSE を返します。

表 1. オブジェクトのプロパティ

プロパティ説明
nameカラムの名前。
orgnameもしエイリアスが指定されている場合の、本来の名前。
tableフィールドが属するテーブルの名前。
orgtableもしエイリアスが指定されている場合の、本来のテーブル名。
defフィールドのデフォルト値。文字列形式。
max_length結果セットにおけるフィールドの最大幅。
lengthテーブルの定義で指定されているフィールド幅。
charsetnrフィールドの文字セット番号。
flagsフィールドのビットフラグを整数型で表す。
typeフィールドのデータ型。
decimalsフィールドの桁数(integer 型のフィールド)。

参考

mysqli_num_fields()mysqli_fetch_field_direct()mysqli_fetch_fields() そして mysqli_field_seek()

例 1. オブジェクト指向型

<?php
$mysqli
= new mysqli("localhost", "my_user", "my_password", "world");

/* 接続状況をチェックします */
if (mysqli_connect_errno()) {
    
printf("Connect failed: %s\n", mysqli_connect_error());
    exit();
}

$query = "SELECT Name, SurfaceArea from Country ORDER BY Code LIMIT 5";

if (
$result = $mysqli->query($query)) {

    
/* すべてのカラムのフィールド情報を取得します */
    
while ($finfo = $result->fetch_field()) {

        
printf("Name:     %s\n", $finfo->name);
        
printf("Table:    %s\n", $finfo->table);
        
printf("max. Len: %d\n", $finfo->max_length);
        
printf("Flags:    %d\n", $finfo->flags);
        
printf("Type:     %d\n\n", $finfo->type);
    }    
    
$result->close();
}

/* 接続を閉じます */
$mysqli->close();
?>

例 2. 手続き型

<?php
$link
= mysqli_connect("localhost", "my_user", "my_password", "world");

/* 接続状況をチェックします */
if (mysqli_connect_errno()) {
    
printf("Connect failed: %s\n", mysqli_connect_error());
    exit();
}

$query = "SELECT Name, SurfaceArea from Country ORDER BY Code LIMIT 5";

if (
$result = mysqli_query($link, $query)) {

    
/* すべてのカラムのフィールド情報を取得します */
    
while ($finfo = mysqli_fetch_field($result)) {

        
printf("Name:     %s\n", $finfo->name);
        
printf("Table:    %s\n", $finfo->table);
        
printf("max. Len: %d\n", $finfo->max_length);
        
printf("Flags:    %d\n", $finfo->flags);
        
printf("Type:     %d\n\n", $finfo->type);
    }
    
mysqli_free_result($result);
}

/* 接続を閉じます */
mysqli_close($link);
?>

上の例の出力は以下となります。

Name:     Name
Table:    Country
max. Len: 11
Flags:    1
Type:     254

Name:     SurfaceArea
Table:    Country
max. Len: 10
Flags:    32769
Type:     4