Ограничить и контролировать столбцы данных, которые можно заказать?

У меня есть данные, где столбцы Нет, Фамилия, Имя, Детали. В настоящее время во всех 4 столбцах отображаются символы asc и desc. Мне нужно ограничить порядок только для столбца LastName и FirstName. Ниже мой скрипт, который выполняет обработку сервера. Ниже показано, как мои php-коды, которые я использую для сбора данных и внесения в мою сетку. Проблема в том, что в первом столбце нет. Поэтому, когда я использую эти коды, я просто получаю заказ только на основе столбца № только. Как сделать заказ только по Фамилии или Фамилии?

$requestData= $_REQUEST;
$columns = array(
// datatable column index  => database column name
0 => 'fName',
1=> 'lName'
);

$query = "Select fName,lName,details From User";

if(!empty($requestData['search']['value']) ) {
$query.=" AND ( fName LIKE :searchKey )";
}
$selectQueryResult1 = $link->prepare($query);

$arr = $selectQueryResult1->errorInfo();
$totalData=$selectQueryResult1->rowCount();
$totalFiltered = $totalData;

$query.=" ORDER BY ". $columns[$requestData['order'][0]['column']]."   ".$requestData['order'][0]['dir']."  LIMIT ".$requestData['start']." ,".$requestData['length']."   ";
//echo "query : ".$query;

$selectQueryResult1 = $link->prepare($query);
if(!empty($requestData['search']['value']) ) {   // if there is a search parameter, $requestData['search']['value'] contains search parameter

$searchKey = $requestData['search']['value'];
$searchKey="%$searchKey%";
$selectQueryResult1->bindParam(':searchKey',$searchKey );}
$selectQueryResult1->execute();$i=0;
$i=$requestData['start']+$i;
while($row = $selectQueryResult1->fetch())
{
$nestedData=array();
$i++;

$nestedData[] = $i;
$nestedData[] = $row["fName"];
$nestedData[] = $row["lName"];
$nestedData[] = $row["details"];

$data[] = $nestedData;
}

if($totalData>0){
$json_data = array(
"draw"            => intval( $requestData['draw'] ),
"recordsTotal"    => intval( $totalData ),
"recordsFiltered" => intval( $totalFiltered ),
"data"            => $data
);
}
else{
$json_data = array(
"draw"            => intval( $requestData['draw'] ),
"recordsTotal"    => intval( $totalData ),
"recordsFiltered" => intval( $totalFiltered ),
"data"            => "");
}

0

Решение

Вы хотите предоставить пользователю возможность заказа только по фамилии или имени, правильно?

Это опция инициализации DataTables:

columns.orderable Включить или отключить порядок в этом столбце

увидеть: Опции для деталей.

1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]