php - DataTable 格式化表中的日期时间列

标签 php jquery mysql datetime datatable

我正在使用 DataTable 插件以动态方式显示 mySQL 数据库表。该表对“checkinDateTime”列使用日期时间格式。在我的表格中,它将日期/时间格式设置为 2016-04-15 14:27:36。我想让它更具可读性,格式可能类似于 2016 年 4 月 15 日下午 2:27

这是我的代码:

Reports.php(这是用户可以查看表格的地方。我只显示 DataTables 脚本及其设置):

<script>
    $(document).ready(function() {

        $('#checkin').DataTable({
        "bProcessing": true,
        "serverSide": false,
        "dom": 'lBfrtip',
     "buttons": [
        {
            extend: 'collection',
            text: 'Export',
            buttons: [
                'copy',
                'excel',
                'csv',
                'pdf',
                'print'
            ]
        }
    ],
        "ajax":{
            url :"response.php", // json datasource
            type: "post",  // type of method  ,GET/POST/DELETE
            data: {}
            }
        });   
});
</script>

Response.php(DataTables 如何提取数据):

<?php
//include connection file 
include_once("../connection.php");

// initilize all variable
$params = $columns = $totalRecords = $data = array();

$params = $_REQUEST;

//define index of column
$columns = array( 
0 => 'id',
1 => 'suid', 
2 => 'staffMember',
3 => 'studentName',
4 => 'studentEmail',
5 => 'checkinDateTime'
);

$where = $sqlTot = $sqlRec = "";

// check search value exist
if( !empty($params['search']['value']) ) {   
$where .=" WHERE ";
$where .=" ( studentName LIKE '".$params['search']['value']."%' ";    
$where .=" OR staffMember LIKE '".$params['search']['value']."%' ";
$where .=" OR studentEmail LIKE '".$params['search']['value']."%' ";
$where .=" OR suid LIKE '".$params['search']['value']."%' ";
$where .=" OR checkinDate LIKE '".$params['search']['value']."%' )";
}

// getting total number records without any search
$sql = "SELECT * FROM `checkin` ";
$sqlTot .= $sql;
$sqlRec .= $sql;
//concatenate search sql if value exist
if(isset($where) && $where != '') {

$sqlTot .= $where;
$sqlRec .= $where;
}


//$sqlRec .=  " ORDER BY ". $columns[$params['order'][0]['column']]."   ".$params['order'][0]['dir']."  LIMIT ".$params['start']." ,".$params['length']." ";

$queryTot = mysqli_query($VisitorManagement, $sqlTot) or die("database error:". mysqli_error($VisitorManagement));


$totalRecords = mysqli_num_rows($queryTot);

$queryRecords = mysqli_query($VisitorManagement, $sqlRec) or die("error to fetch check-in data");

//iterate on results row and create new index array of data
while( $row = mysqli_fetch_row($queryRecords) ) { 
$data[] = $row;
}   

$json_data = array(
    "draw"            => intval( $params['draw'] ),   
    "recordsTotal"    => intval( $totalRecords ),  
    "recordsFiltered" => intval($totalRecords),
    "data"            => $data   // total data array
    );

echo json_encode($json_data);  // send data as json format
?>

Connection.php(访问数据库):

<?php
$hostname_VisitorManagement = "localhost";
$database_VisitorManagement = "visitor-management";
$username_VisitorManagement = "****";
$password_VisitorManagement = "****";
$VisitorManagement = mysqli_connect($hostname_VisitorManagement, $username_VisitorManagement, $password_VisitorManagement, $database_VisitorManagement);

if (mysqli_connect_errno()) {
printf("Connect failed: %s\n", mysqli_connect_error());
exit();
}

date_default_timezone_set('America/New_York');
?>

我浏览了他们的支持论坛和这里,但我没有找到可以使用我的代码的解决方案。

最佳答案

我建议通过 MySql 来执行此操作,而不是

SELECT * FROM `checkin`

使用

Select field1,field2,..., date_format(checkinDateTime,'%d %b, %Y, %h:%i %p') as checkinDateTime

如果不起作用,请通过 datatables's date plugin 进行操作

关于php - DataTable 格式化表中的日期时间列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37791276/

相关文章:

php - AsyncTask Android 中的 Http 请求

mysql - Web 应用程序数据库设计的替代方案

javascript - CORS 问题 - "No ' Access-Control-Allow-Origin header 出现在请求的资源上。”

php - PHP 中的 Rails "respond_to"

php - 搜索没有撇号的词(有撇号的)

javascript - Jquery .click() 标题不起作用

javascript - 为什么要生成渲染空图像文件的 Canvas ?

php - 显示 "Form"中的所有类别 选择选项下拉列表

php - 使用 PHPSpec 安排/执行/断言模式

javascript - 如何在提交前更改隐藏输入字段的值