I just upgraded mysql jdbc connection JAR (from mysql-connector-java-5.0.5.jar to mysql-connector-java-8.0.19.jar) and the project started showing error for import statements:
import com.mysql.jdbc.PreparedStatement;
java: cannot find symbol
symbol: class PreparedStatement
location: class package.ClassName
Where to find the location or package for PreparedStatement in new jar file or is it replaced with any other class in new JAR?
com.mysql.jdbc.PreparedStatement
is an internal class to the MySQL 5.x JDBC driver. Your code should not import it. It should be using the standard java.sql.PreparedStatement
class instead.
The package names have changed in the MySQL 8.x JDBC drivers, and that is what caused your code to start giving compilation errors.
Solution:
Fix your code so that it doesn't import any MySQL implementation classes 1 . Use the java.sql.*
and javax.sql.*
class instead.
Change your project dependencies so that the MySQL driver JAR is not a compile-time dependency. Doing that will cause any accidental source code dependencies on JDBC drivers to be flagged as compilation errors. It will also stop your IDE from making incorrect suggestions for import
statements. (My guess is that that is how the bogus import got into your codebase.)
If your code is (still) using Class.forName
to load the JDBC driver, change it to use java.sql.DriverManager
instead; see javadoc . That way you won't be burned by another change in the MySQL driver class name.
1 - Your Java code should not need to depend on MySQL-specific APIs. As far as I know, the MySQL implementation classes mirror the standard JDBC APIs, so you gain nothing by using them directly. This is not true for all vendors.
Try to replace it with:
import java.sql.PreparedStatement;
Using com.mysql.jdbc.PreparedStatement
is specific to mysql, and should not be imported directly.
So unless you need MySQL specific features, it's always better to use the interface java.sql.PreparedStatement
that is database independent. See also this .
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.