Mysql
 sql >> Baza danych >  >> RDS >> Mysql

MySql określa przesunięcie wiersza z wyniku zapytania

Więc z twoim przykładem tabeli:

username    ticket_number   queue_time
Doc             0               0                  The 1st 3 not in sorted result
Grumpy          0               0
Happy           0               0
Sleepy          1               111                The following are in sorted result
Bashful         2               222
Sneezy          0               333
SnowWhite       ???             444               This is the current user (assign ???=4)
Dopey           0               555
EvilQueen       0               666

jak przypisać wartość 4 do kolumny numer_biletu nazwy użytkownika SnowWhite, gdzie 4 jest pozycją wiersza w posortowanej selekcji początkowych wierszy:

najpierw uzyskaj posortowany wynik:

$result = mysql_query("SELECT * FROM table WHERE [here the condition for your sorted array]"); 
// don't forget to remove the []. they don't go there.
while ($row = mysql_fetch_assoc($result))
 {$array[] = $row;}

to powinno dać ci coś takiego:

[0]   [username]        [Sleepy]
      [ticket_number]   [1]
      [queue_time]      [111]
[1]   [username]        [Bashful]
      [ticket_number]   [2]
      [queue_time]      [222]
[2]   [username]        [Sneezy]
      [ticket_number]   [0]
      [queue_time]      [333]
[3]   [username]        [SnowWhite]
      [ticket_number]   [NULL]
      [queue_time]      [444]

następnie foreach przez tablicę

    foreach ($array as $number => $row)
     {if ($row[username] == $userinfo)
       {$result = mysql_query('UPDATE table SET ticket_numer=' . ($number+1) . ' WHERE username=' . $userinfo);}}

wiersz odpowiadający nazwie użytkownika SnowWhite otrzyma ($numer + 1) (3 + 1) jako numer_biletu




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Złożone zapytania do bazy danych w yii2 z Active Record

  2. Jak wyświetlić wszystkie nazwy tabel z konkretnej bazy danych mysql w php?

  3. Wydobywanie czasu na ponowne dołączenie

  4. BIN() — pobierz wartość binarną liczby w MySQL

  5. Blokada metadanych w MySQL 5.7, nie możesz znaleźć procesu blokowania?