Maison >base de données >tutoriel mysql >Puis-je exécuter plusieurs requêtes dans une seule instruction à l'aide de JDBC Connector/J dans MySQL ?
Exécuter plusieurs requêtes dans MySQL avec JDBC Connector/J
Dans MySQL Connector/J, l'exécution de plusieurs requêtes séparées par un point-virgule n'est généralement pas soutenu. Au lieu de cela, les requêtes doivent être exécutées séparément.
Raison de l'erreur
Lorsque vous utilisez la méthode d'exécution pour exécuter une instruction SQL contenant plusieurs requêtes séparées par des points-virgules, vous rencontrer une MySQLSyntaxErrorException. En effet, dans la plupart des bases de données, y compris MySQL, le point-virgule est utilisé comme terminateur d'instruction plutôt que dans le cadre de la syntaxe de l'instruction.
Option spécifique à MySQL
MySQL fournit une option appelée AllowMultiQueries qui peut être activée pour permettre l'exécution de plusieurs requêtes dans une seule instruction. Cependant, cela n'est pas conforme à la spécification JDBC et peut rendre votre code moins portable.
Bonne pratique
Pour une portabilité et une compatibilité optimales avec la spécification JDBC, il est Il est recommandé d'exécuter plusieurs requêtes séparément. Voici un exemple :
Statement statement = connection.createStatement(); statement.execute("select fullName from user where user_id=1"); ResultSet resultSet1 = statement.getResultSet(); statement.execute("select fullName from user where user_id=2"); ResultSet resultSet2 = statement.getResultSet();
En exécutant les requêtes séparément, vous évitez les erreurs de syntaxe potentielles et vous assurez que votre code est conforme aux standards JDBC.
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!