Как объединить две таблицы с помощью ssp.class.php

Я начал использовать плагин DataTables Table для jQuery и получил некоторые проблемы. Я использую пример кода отсюда.

У меня MySQL таблица ведьм выглядит так:

id | имя | father_id

father_id является id значение в одной таблице только в другой строке. Так что, если я хочу узнать имя отца, я должен искать в той же таблице WHERE id = father_id, Но что делает DataTable, он просто показывает содержимое таблицы MySQL как есть.

В моем DataTable я хочу показать такие данные:

id | имя | имя отца | father_id

Поэтому, когда DataTable берет данные из таблицы MySQL, но перед тем, как создать таблицу, я хочу изменить значение столбца, которое в то время является значением father_id в той же строке в MySQL. Я тоже хочу добавить father_name ища его с особым father_id,

3 ответа

Решение

Как указал 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 назначить псевдоним.

ЗАМЕТКИ

Существует также https://github.com/emran/ssp репозиторий, который содержит расширенные ssp.class.php поддерживающие СОЕДИНЕНИЯ.

ССЫЛКИ

Посмотрите jQuery DataTables: Использование WHERE, JOIN и GROUP BY с ssp.class.php для получения дополнительной информации.

Недавно я обнаружил, что использую DataTables и требует более сложного предложения JOIN и WHERE, которое не поддерживал оригинальный ssp.class.php. Поэтому я изменил исходный файл и немного изменил API, чтобы получить таблицу, которая дала мне необходимую гибкость. Я объединил функциональность "SSP::simple" и "SSP::complex" в одну функцию с именем "SSP::process".

Из-за длины скрипта я поместил его на pastebin.com здесь: ssp.class.php

И быстрый пример того, как я его использую:

private function get_recent_payments() {
    global 
        $pdoHost, $pdoUser, 
        $pdoPass, $pdoDatabase;

    // SQL server connection information
    $sql_details = array(
        'user' => $pdoUser,
        'pass' => $pdoPass,
        'db'   => $pdoDatabase,
        'host' => $pdoHost
    );

    // DataTables server-side processing
    require_once('ssp.class.php');

    $options = [
        'table' => 'payments',
        'alias' => 'l',
        'primaryKey' => 'id',
        'columns' => [
            [ 'db' => 'id',       'dt' => 0 ],
            [
                'db' => 'client_id',     
                'dt' => 1,
                'join' => [
                    'table' => 'clients',
                    'on' => 'id',
                    'select' => 'first_name',
                    'alias' => 'c',
                    'as' => 'fname',
                ]
            ],
            [
                'db' => 'client_id',     
                'dt' => 2,
                'join' => [
                    'table' => 'clients',
                    'on' => 'id',
                    'select' => 'last_name',
                    'alias' => 'c'
                ]
            ],
            [ 'db' => 'pay_date', 'dt' => 3 ]
        ],
        'where' => [
            [
                'db' => 'client_id',
                'op' => '!=',
                'value' => $_SESSION['client_id']
            ]
        ]
    ];

    $this->response(SSP::process($_REQUEST, $sql_details, $options));
}

Предложения 'where' и 'whereResult' (SEE 'SSP::complex' for Details) массива параметров также могут иметь псевдоним для ссылки на столбец в объединенной таблице.

Пример SQL-запроса, переданного на сервер:

SELECT l.`id`, c.`first_name` AS 'fname', c.`last_name`, l.`pay_date` 
        FROM `payments` l
        JOIN `clients` c ON (c.`id` = l.`client_id`)
        WHERE l.`client_id` != :binding_0
        ORDER BY l.`pay_date` DESC
        LIMIT 0, 5

Я выбрал маршрут структурированного массива, потому что это позволило мне строить запросы, поддерживая жесткость запросов с обратными галочками и параметрами связанного оператора. Я выкладываю этот пост в надежде, что другие найдут его таким же полезным, как и я.

Присоединяйтесь к таблице с самим собой - вам нужно будет использовать псевдонимы

SELECT a.id, a.name, b.name, b.id
FROM table a
join table b on (b.father_id=a.id);
Другие вопросы по тегам