Как выбрать последние изменения, сделанные в данной структуре таблицы? - PullRequest
0 голосов
/ 03 мая 2010

У меня есть структура таблицы как id, trackid, table_name, операция, oldvalue, newvalue, поле, changeonetime

Теперь, если у меня есть 3 строки для одного и того же "trackid" одного и того же "поля", то как я могу выбрать самый последний из трех?

т.е. например ,:

id = 100 trackid = 152 имя_таблицы = jos_menu операция = ОБНОВЛЕНИЕ старое значение = IPL новое значение = IPLcccc поле = имя в прямом эфире = 0 изменено один раз = 2010-04-30 17: 54: 39

и

id = 101 trackid = 152 table_name = jos_menu операция = ОБНОВЛЕНИЕ старое значение = IPLcccc новое значение = IPL2222 поле = имя в прямом эфире = 0 изменено один раз = 2010-04-30 18: 54: 39

Как вы можете видеть выше, вторая запись - это последнее изменение, Теперь какой запрос я должен использовать, чтобы получить единственную и последнюю строку из множества таких строк ...

ОБНОВЛЕНО

$distupdqry = "select DISTINCT trackid,table_name from jos_audittrail where live = 0 AND operation = 'UPDATE'";
$disupdsel = mysql_query($distupdqry);
$t_ids = array();
$t_table = array();
while($row3 = mysql_fetch_array($disupdsel))
{   
    $t_ids[] = $row3['trackid'];
    $t_table[] = $row3['table_name'];
    //$t_table[] = $row3['table_name'];
}

//echo "<pre>";print_r($t_table);echo "<pre>";

//exit;
for($n=0;$n<count($t_ids);$n++)
{

      $qupd = "SELECT * FROM jos_audittrail WHERE operation = 'UPDATE'  AND trackid=$t_ids[$n] order by changedone DESC ";
    $seletupdaudit = mysql_query($qupd);
    $row4 = array();
    $audit3 = array();
    while($row4 = mysql_fetch_array($seletupdaudit))
    {   
        $audit3[] = $row4;  
    }           


        $updatefield = '';
        for($j=0;$j<count($audit3);$j++)
        {
            if($j == 0)
            {

                if($audit3[$j]['operation'] == "UPDATE")
                {
                            //$insqry .= $audit2[$i]['operation']." ";
                            //echo "<br>";
                    $updatefield .= "UPDATE `".$audit3[$j]['table_name']."` SET ";

                }
            }

            if($audit3[$j]['operation'] == "UPDATE")
            {

                $updatefield .= $audit3[$j]['field']." = '".$audit3[$j]['newvalue']."', ";

            }

        }
        /*echo "<pre>";
    print_r($audit3);
    exit;*/
        $primarykey = "SHOW INDEXES FROM `".$t_table[$n]."` WHERE Key_name = 'PRIMARY'";
        $prime = mysql_query($primarykey);
        $pkey = mysql_fetch_array($prime);
        $updatefield .= "]";
        echo $updatefield = str_replace(", ]"," WHERE ".$pkey['Column_name']." = '".$t_ids[$n]."'",$updatefield);   
}

Здесь я создаю запрос на обновление, извлекая записи из первоначально описанной таблицы, которая здесь упоминается как таблица audtrail ... пожалуйста, ознакомьтесь с кодом ... и посмотрите, как я могу внести необходимые изменения, которые мне нужны, наконец ...

1 Ответ

1 голос
/ 03 мая 2010
select * from TableName order by id DESC LIMIT 1

Редакция. ДА вы можете, если вы хотите сделать заказ, используя «changeonetime» USE.

select * from TableName order by changedonetime DESC LIMIT 1
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...