Dépannage de la commande de sélection refusée dans MySQL
Dans un site Web MySQL utilisant un service Web pour les opérations de base de données, une erreur est rencontrée :
select command denied to user '<userid>'@'<ip-address>' for table '<table-name>'
Cette erreur se produit généralement sur la ligne où MySqlDataReader.ExecuteReader() est appelé. Vous trouverez ci-dessous le code correspondant :
String addSQL = "Select Max(`TradeID`) from `jsontest`.`tbl_Positions"; ... MySqlCommand command1 = objMyCon1.CreateCommand(); command1.CommandText = newSQL; MySqlDataReader result1 = command1.ExecuteReader();
Lors de l'exécution du code, le problème survient à la ligne result1 = command1.ExecuteReader();.
Cause possible :
Le message d'erreur indique qu'un utilisateur tente d'exécuter une commande SELECT sur une table, mais ne dispose pas des autorisations nécessaires. Cette erreur peut également se produire en cas de faute de frappe dans l'instruction SQL.
Solution :
Réviser SQL Déclaration : Examinez l'instruction SQL pour détecter toute faute de frappe ou erreur de syntaxe. En particulier, vérifiez les éléments suivants :
Par exemple, assurez-vous que le le nom de la table est tbl_Position et non tbl_Position.
Supplémentaire Notes :
Comme mentionné dans la réponse fournie par l'utilisateur, un problème similaire peut survenir lors de l'utilisation d'une faute de frappe dans une requête UNION. S'il y a un nom de table inexistant dans l'instruction, ce type d'erreur peut en résulter.
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!