首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用ssp.class.php连接两个表

如何使用ssp.class.php连接两个表
EN

Stack Overflow用户
提问于 2015-06-23 13:59:51
回答 3查看 16K关注 0票数 10

我开始使用用于DataTables表的jQuery插件,遇到了一些问题。我正在使用来自这里的示例代码。

我有个MySQL桌子女巫看起来是这样的:

id _(_

father_id是同一表中仅在不同行中的id值。因此,如果我想知道父亲的名字,我必须在同一个表WHERE id = father_id中搜索。但是DataTable做了什么,它只是显示了MySQL表的内容。

在我的DataTable中,我想显示这样的数据:

id _ father_name _

因此,当DataTable从MySQL表中获取数据时,但在创建表之前,我希望更改列值,该列值当时是MySQL中同一行中的father_id值。我也希望通过使用特定的father_name搜索来添加father_id

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-06-23 15:27:10

正如PaulF所指出的,您需要使用JOIN或子查询从同一个表中检索父亲的姓名。

根据您提到的示例,假设您使用ssp.class.php在服务器端处理数据。

ssp.class.php不支持联接和子查询,但有一个解决办法。诀窍是使用子查询,如下面的$table定义所示。将table替换为子查询中的实际表名。

代码语言:javascript
复制
$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支持联接。

链接

有关详细信息,请参阅jQuery DataTables:在ssp.class.php中使用WHERE、JOIN和GROUP

票数 18
EN

Stack Overflow用户

发布于 2016-07-26 16:26:50

最近,我发现自己使用了DataTables,需要一个更复杂的联接和WHERE子句,而最初的ssp.class.php并不支持这些子句。因此,我修改了原始文件,并稍微修改了API,以提供一个表,使我具有所需的灵活性。我将"SSP::simple“和"SSP::complex”的功能组合成一个名为"SSP::process“的函数。

由于脚本的长度,我将其放在pastebin.com上:ssp.class.php

还有一个我如何使用它的简单例子:

代码语言:javascript
复制
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’(有关详细信息,请参见‘SSP::复杂’)子句也可能有一个“别名”来引用联接表中的列。

传递给服务器的SQL查询示例:

代码语言:javascript
复制
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

我采用了结构化数组路由,因为这使我能够构建查询,同时保持带有backticks和绑定语句参数的查询的刚性。我张贴这篇文章是希望其他人会发现它和我一样有用。

票数 1
EN

Stack Overflow用户

发布于 2015-06-23 14:19:16

加入表本身-您将需要使用别名。

代码语言:javascript
复制
SELECT a.id, a.name, b.name, b.id
FROM table a
join table b on (b.father_id=a.id);
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31004884

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档