PaulF
として 指摘されたように、JOIN
を使用する必要があります またはサブクエリを実行して、同じテーブルから父親の名前を取得します。
ssp.class.php
を使用していると思います あなたが言及した例に基づいてサーバー側でデータを処理します。
クラスssp.class.php
結合とサブクエリはサポートされていませんが、回避策があります。秘訣は、以下の$table
に示すようにサブクエリを使用することです。 意味。 table
を置き換えます サブクエリに実際のテーブル名を使用します。
$table = <<<EOT
(
SELECT
a.id,
a.name,
a.father_id,
b.name AS father_name
FROM table a
LEFT JOIN table b ON a.father_id = b.id
) temp
EOT;
$primaryKey = 'id';
$columns = array(
array( 'db' => 'id', 'dt' => 0 ),
array( 'db' => 'name', 'dt' => 1 ),
array( 'db' => 'father_id', 'dt' => 2 ),
array( 'db' => 'father_name', 'dt' => 3 )
);
$sql_details = array(
'user' => '',
'pass' => '',
'db' => '',
'host' => ''
);
require( 'ssp.class.php' );
echo json_encode(
SSP::simple( $_GET, $sql_details, $table, $primaryKey, $columns )
);
ssp.class.php
も編集する必要があります FROM `$table`
のすべてのインスタンスを置き換えます FROM $table
を使用 バックティックを削除します。
すべての列名が一意であることを確認してください。そうでない場合は、AS
を使用してください エイリアスを割り当てる。
注意事項
github.com/emran/ssp
もあります 拡張されたssp.class.php
を含むリポジトリ JOINのサポート。
リンク
jQuery DataTables:ssp.class.phpでWHERE、JOIN、およびGROUPBYを使用する 詳細については。