0

0

DataTables 服务器端处理:添加非数据库计算列的教程

霞舞

霞舞

发布时间:2025-11-29 11:15:43

|

613人浏览过

|

来源于php中文网

原创

DataTables 服务器端处理:添加非数据库计算列的教程

本教程详细介绍了如何在 datatables 的服务器端处理中,通过 ssp (server-side processing) 类添加非数据库来源的计算列。文章将重点讲解 `formatter` 回调函数的使用,通过实际代码示例演示如何基于现有数据动态生成新列的值,从而实现更灵活的数据展示。

引言:DataTables 服务器端处理与动态列需求

DataTables 是一个功能强大的 JavaScript 库,用于增强 HTML 表格的交互性。当处理大量数据时,服务器端处理(Server-side Processing)是必不可少的,它允许 DataTables 将数据检索、过滤、排序和分页等操作委托给服务器,从而减轻客户端的负担并提高性能。

在实际应用中,我们经常需要展示一些不直接存储在数据库中的列,这些列的值可能需要根据现有数据库字段进行计算、组合或格式化。例如,一个“评分”列可能需要根据“薪资”和“职位”等字段动态计算得出。本文将详细阐述如何在 DataTables 的服务器端处理中优雅地实现这类非数据库计算列。

核心机制:formatter 回调函数

DataTables 的 SSP (Server-side Processing) 类在处理 $columns 数组时提供了一个强大的 formatter 选项。这个 formatter 是一个回调函数,它允许开发者在数据发送到客户端之前,对每一列的每个单元格数据进行自定义处理。

formatter 函数接收两个关键参数:

  1. $d:当前列的原始数据库值。
  2. $row:一个关联数组,包含了当前行所有数据库字段的键值对。这个参数对于创建计算列至关重要,因为它允许我们访问同一行的其他数据进行计算。

通过利用 formatter 函数,我们可以完全控制列的输出内容,无论是简单的格式化、复杂的逻辑判断,还是基于其他列数据进行全新值的计算。

实现步骤与示例

要添加一个非数据库来源的计算列,我们需要在服务器端的 PHP 脚本中,修改 $columns 数组的定义。

步骤一:定义服务器端 $columns 数组

首先,回顾 DataTables 服务器端处理中 $columns 数组的基本结构。每个数组元素代表一个表格列,并至少包含 'db' (数据库列名) 和 'dt' (DataTables 列索引) 键。

<?php
// ... 其他配置,如 $table, $primaryKey, $sql_details ...

$columns = array(
    array( 'db' => 'first_name', 'dt' => 0 ),
    array( 'db' => 'last_name',  'dt' => 1 ),
    array( 'db' => 'position',   'dt' => 2 ),
    array( 'db' => 'office',     'dt' => 3 ),
    array(
        'db'        => 'start_date',
        'dt'        => 4,
        'formatter' => function( $d, $row ) {
            return date( 'jS M y', strtotime($d));
        }
    ),
    array(
        'db'        => 'salary',
        'dt'        => 5,
        'formatter' => function( $d, $row ) {
            return '$'.number_format($d);
        }
    )
);

// ... SSP::simple 调用 ...
?>

在上述示例中,start_date 和 salary 列已经使用了 formatter 进行格式化。我们将在此基础上添加一个全新的计算列。

Programming Helper
Programming Helper

AI代码自动生成器,在AI的帮助下更快地编程

下载

步骤二:添加计算列配置

为了添加一个名为“Rating”(评分)的计算列,我们需要在 $columns 数组中增加一个新的项。

对于非数据库来源的计算列,'db' 键的设置是一个关键点:

  • 策略: 将 'db' 键指向一个现有且必然存在的数据库列(例如,主键 id 或任何其他总是被查询的列)。这是因为 SSP 类会根据这些 'db' 键构建 SQL SELECT 语句。如果指向一个不存在的列,SQL 查询会失败。
  • 实际值: 即使 'db' 键指向了某个数据库列,我们也会在 'formatter' 函数中完全覆盖其值,所以它实际指向哪个数据库列并不重要,只要它能让 SQL 查询成功即可。

以下是添加“Rating”计算列的完整示例:

<?php

// 假设这是您的服务器端处理脚本 (e.g., ssp.class.php 所在目录的 index.php 或 data.php)

// 数据库连接详情
$sql_details = array(
    'user' => 'your_db_user',
    'pass' => 'your_db_password',
    'db'   => 'your_db_name',
    'host' => 'localhost'
);

// 表名
$table = 'datatables_demo'; // 替换为您的实际表名

// 表的主键
$primaryKey = 'id';

// 定义 DataTables 列
$columns = array(
    array( 'db' => 'id',         'dt' => 0 ), // 将 id 作为第一列,或任何您希望的列
    array( 'db' => 'first_name', 'dt' => 1 ),
    array( 'db' => 'last_name',  'dt' => 2 ),
    array( 'db' => 'position',   'dt' => 3 ),
    array( 'db' => 'office',     'dt' => 4 ),
    array(
        'db'        => 'start_date',
        'dt'        => 5,
        'formatter' => function( $d, $row ) {
            return date( 'jS M y', strtotime($d));
        }
    ),
    array(
        'db'        => 'salary',
        'dt'        => 6,
        'formatter' => function( $d, $row ) {
            return '$'.number_format($d);
        }
    ),
    // 添加我们的新计算列:Rating
    array(
        'db'        => 'id', // 使用 'id' 作为占位符,确保它会被 SQL 查询选中
        'dt'        => 7,    // 新列在 DataTables 中的索引,确保与客户端匹配
        'formatter' => function( $d, $row ) {
            // 从 $row 数组中获取其他列的值进行计算
            $salary = (int)$row['salary'];
            $position = $row['position'];
            $firstName = $row['first_name'];

            // 执行您的自定义计算逻辑
            $rating = 0;

            // 基于薪资计算评分
            if ($salary > 100000) {
                $rating += 5;
            } elseif ($salary > 50000) {
                $rating += 3;
            } else {
                $rating += 1;
            }

            // 基于职位计算评分
            if (strpos($position, 'Manager') !== false) {
                $rating += 4;
            } elseif (strpos($position, 'Developer') !== false) {
                $rating += 2;
            }

            // 也可以基于其他字段,例如姓名的长度
            if (strlen($firstName) > 5) {
                $rating += 1;
            }

            // 返回计算出的评分
            return $rating;
        }
    )
);

// 引入 SSP 类
require( 'ssp.class.php' ); // 确保路径正确

// 输出 JSON 响应
echo json_encode(
    SSP::simple( $_GET, $sql_details, $table, $primaryKey, $columns )
);

?>

在这个示例中,我们添加了一个索引为 7 的新列。它的 db 键被设置为 id,这意味着在服务器端查询时,id 列会被选中。然而,formatter 函数会完全忽略 id 的原始值 $d,而是利用 $row 数组中 salary、position 和 first_name 的值来计算并返回一个全新的“Rating”值。

步骤三:客户端 DataTables 配置 (简述)

在客户端的 JavaScript 中,您需要确保 DataTables 的 columns 配置与服务器端返回的列数和顺序相匹配。

$(document).ready(function() {
    $('#example').DataTable({
        'processing': true,
        'serverSide': true,
        'ajax': 'your_server_side_script.php', // 替换为您的服务器端脚本路径
        'columns': [
            { 'data': 0 }, // id
            { 'data': 1 }, // first_name
            { 'data': 2 }, // last_name
            { 'data': 3 }, // position
            { 'data': 4 }, // office
            { 'data': 5 }, // start_date (formatted)
            { 'data': 6 }, // salary (formatted)
            { 'data': 7 }  // Rating (calculated)
        ]
    });
});

注意事项与最佳实践

  1. 性能考量: formatter 函数会在每一行数据被处理时执行。因此,在其中执行的计算逻辑应尽可能高效。避免在 formatter 中进行额外的数据库查询或耗时过长的操作,这会严重影响服务器端处理的性能。
  2. 数据访问: 充分利用 $row 数组。它包含了当前行所有被选中的数据库字段。这意味着您无需为计算列单独查询数据库,所有所需数据都已在手。
  3. 'db' 键的策略: 对于完全由 formatter 生成的计算列,'db' 键虽然其值会被覆盖,但它仍然是 SSP 类构建 SQL SELECT 语句所必需的。因此,务必将其指向一个存在的数据库列(如 id 或任何您希望在 SELECT 语句中出现的列)。
  4. 可读性与维护性: 如果计算逻辑非常复杂,可以考虑将其封装成一个独立的 PHP 函数,然后在 formatter 中调用该函数,以提高代码的可读性和可维护性。
  5. 排序与搜索: 默认情况下,DataTables 会尝试对所有列进行排序和搜索。对于计算列,DataTables 无法直接在数据库层面进行排序和搜索。
    • 排序: 如果需要对计算列进行排序,您可能需要实现自定义排序逻辑,或者在数据库层面预先计算并存储该值(如果业务允许)。
    • 搜索: 同样,直接对计算列进行服务器端搜索是困难的。如果需要,您可能需要在 SSP::simple 之前对 $columns 数组进行更高级的定制,或者在 formatter 中返回一个可搜索的字符串。

总结

通过 DataTables SSP 类的 formatter 回调函数,开发者可以灵活地在服务器端处理中添加非数据库来源的计算列。这一功能极大地增强了 DataTables 的数据展示能力,允许我们在不修改数据库结构的前提下,根据业务需求动态生成和展示复杂的数据。掌握 formatter 的使用,特别是如何利用 $row 参数进行跨列计算,是实现高效且功能丰富的 DataTables 应用的关键。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1133

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2174

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1683

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

440

2024.04.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.4万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号