Foros del Web » Programando para Internet » Javascript » Frameworks JS »

Ordenando DataTable y pasando de pagina

Estas en el tema de Ordenando DataTable y pasando de pagina en el foro de Frameworks JS en Foros del Web. Hola despues de intentar con el jqgrid me di por vencido pues no me dio los resultados que deseaba buscando en la web encontre el ...
  #1 (permalink)  
Antiguo 21/12/2011, 09:50
Avatar de rafaely2011  
Fecha de Ingreso: septiembre-2011
Ubicación: Sancti Spiritus
Mensajes: 10
Antigüedad: 14 años, 1 mes
Puntos: 0
Pregunta Ordenando DataTable y pasando de pagina

Hola despues de intentar con el jqgrid me di por vencido pues no me dio los resultados que deseaba buscando en la web encontre el Datatable y hasta el momento he logrado gran parte de lo que quiero pero todabia no acabo de entender bien como funciona esto en fin aqui les traigo mi problema para ver si pueden ayudarme.

Lo que me pasa es que todo me pincha bien el filtro por campo pero no asi el ordenar por columna y al cambiar de pagina me sigue mostrando los mismos registros de ante mano gracias

mi codigo php tomado del foro de http://www.datatables.net y modificado a mis necesidades

Código:
<?php
/* MSSQL connection */
    //require('connect.php');
    //i used am include for my connection  
	/* Database connection information */
	$gaSql['user']       = "usuario";
	$gaSql['password']   = "Password";
	$gaSql['db']         = "basedato";
	$gaSql['server']     = "server";
	
		 /* MSSQL connection*/
	$gaSql['link'] =  mssql_pconnect( $gaSql['server'], $gaSql['user'], $gaSql['password']  ) or
		die( 'Could not open connection to server' );
	
	mssql_select_db( $gaSql['db'], $gaSql['link'] ) or 
		die( 'Could not select database '. $gaSql['db'] );
	     
    //Count of all records
    $cQuery = "SELECT COUNT(*) as total_count FROM  ajax";   
    $rResultTotal = mssql_query($cQuery);   
    $aResultTotal = mssql_fetch_array($rResultTotal);
    $iTotal = $aResultTotal[0];
    //print_r ($aResultTotal);
     
     
    /******  Paging  ********/
    $sLimit = "";
    if ( isset( $_GET['iDisplayStart'] ) )
    {
        $sLimit = "TOP ".( $_GET['iDisplayLength'] );
    }
     
    /******* Ordering *********/
    $sOrder = "";
    if ( isset( $_GET['iSortCol_0'] ) )
    {
        $sOrder = "ORDER BY  ";
        for ( $i=0 ; $i<( $_GET['iSortingCols'] ) ; $i++ )
        {
            $sOrder .= fnColumnToField(( $_GET['iSortCol_'.$i] ))."
                ".( $_GET['sSortDir_'.$i] ) .", ";
        }
        $sOrder = substr_replace( $sOrder, "", -2 );
    }
     
    

    /* Filtering - NOTE this does not match the built-in DataTables filtering which does it
     * word by word on any field. It's possible to do here, but concerned about efficiency
     * on very large tables, and MySQL's regex functionality is very limited
      
     SELECT FIELD NAMES
        From table_name    
      
    */
    $sWhere = "";
    if ( $_GET['sSearch'] != "" )
    {
        $sWhere = "WHERE  engine LIKE '%".$_GET['sSearch']."%' 
		            OR "."browser LIKE '%".$_GET['sSearch']."%'
		        	OR "."platform LIKE '%".$_GET['sSearch']."%'
					OR "."version LIKE '%".$_GET['sSearch']."%' 
					OR "."grade LIKE '%".$_GET['sSearch']."%'";
    }
     
     
    $fil_Query = "SELECT COUNT(*) as filert_info
        From ajax
        $sWhere    
    ";
    $fil_Result = mssql_query($fil_Query);
    $afil_Result = mssql_fetch_array($fil_Result);
    $iFilteredTotal = $afil_Result[0];
	
/////////////////////////////////////////////////////////////////////////////// 
//          AQUI ESTAN Los campos a mostrar en el grid    		//
//          $sQuery = "SELECT ".$sLimit." FIELD NAMES		//
///////////////////////////////////////////////////////////////////////////////
     $sQuery = "SELECT ".$sLimit." engine,browser,platform,version,grade
      From ajax
      $sWhere
    ";
    $rResult = mssql_query($sQuery) ;
     
     
    $sOutput = '{';
    $sOutput .= '"sEcho": '.intval($_GET['sEcho']).', ';
    $sOutput .= '"iTotalRecords": '.$iTotal.', ';
    $sOutput .= '"iTotalDisplayRecords": '.$iFilteredTotal.', ';
    $sOutput .= '"aaData": [ ';
    while ( $aRow = mssql_fetch_array( $rResult ) )
    {
        $sOutput .= "[";
        $sOutput .= '"'.$aRow[0].'",';
        $sOutput .= '"'.$aRow[1].'",';
        $sOutput .= '"'.$aRow[2].'",';
        $sOutput .= '"'.$aRow[3].'",';
        $sOutput .= '"'.$aRow[4].'"';
        $sOutput .= "],";
    }
    $sOutput = substr_replace( $sOutput, "", -1 );
    $sOutput .= '] }';
     
    echo $sOutput;
     
    function fnColumnToField( $i )
    {
        if ( $i == 0 )
            return "engine";
        else if ( $i == 1 )
            return "browser";
        else if ( $i == 2 )
            return "platform";
        else if ( $i == 3 )
            return "version";
		else if ( $i == 4 )
            return "grade";			
         
    }
?>

Etiquetas: ajax, datatable, funcion, pasando, php
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 04:10.