Votre question implique la mise à jour de plusieurs enregistrements de base de données avec une seule requête, en particulier lorsque la modification est basée sur une seule modification d'enregistrement. Dans votre cas, vous souhaitez ajuster l'ordre des éléments dans une liste en fonction du mouvement d'un élément particulier.
Il existe plusieurs façons d'aborder cela en utilisant SQL. Une méthode, que vous avez mentionnée, consiste à utiliser plusieurs requêtes. Commencez par sélectionner les enregistrements pertinents, puis utilisez le code de programmation pour modifier les données et mettre à jour les enregistrements. Cependant, comme vous l'avez noté, cette approche n'est pas idéale en raison de sa nature synchrone et de son potentiel de requêtes multiples.
Une autre solution basée sur SQL consiste à exploiter l'instruction suivante :
<code class="sql">UPDATE my_table SET position = position * 10;</code>
Cette modifie les données de manière à faciliter les mises à jour faciles des enregistrements. Pour déplacer un élément vers le haut ou vers le bas de la liste, vous pouvez mettre à jour le champ de position de cet élément en conséquence. Par exemple, pour faire de Poires le deuxième élément, vous utiliseriez :
<code class="sql">UPDATE my_table SET position = 15 WHERE listId=1 AND name = 'Pears';</code>
Cela attribue à Poires une position 10 fois supérieure à sa valeur précédente. Cependant, si vous continuez à apporter des modifications, des écarts peuvent apparaître entre les positions des éléments. Pour éviter cela, exécutez périodiquement la requête suivante :
<code class="sql">UPDATE my_table SET position = position * 10;</code>
Cela garantira qu'il y a toujours 9 positions disponibles entre chaque élément. En implémentant ces instructions SQL, vous pouvez mettre à jour efficacement plusieurs enregistrements avec une seule requête, simplifiant ainsi le processus de réorganisation des éléments dans une liste.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!