当我用JDBC连接MySql数据库时,编译报了如下
错误:错误1:Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.
这要求我们注册驱动时,把Class.forName("com.mysql.jdbc.Driver")改成 Class.forName("com.mysql.cj.jdbc.Driver")
当我信息满满的修改之后重新编译时,再次出现了错误:错误2:Fri Feb 22 08:55:38 CST 2019 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.这要求我们在设置url参数时,将useSSL=false,修改后 jdbc:mysql://localhost:3306/ds3?useSSL=false当我修改后,本以为这下应该没问题了,没想到,再一次出现了问题错误3:Exception in thread "main" java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.这要求我们修改时区,修改成jdbc:mysql://localhost:3306/ds3?useSSL=false&serverTimezone=UTC终于,不在报错误了。错误4:当我们配置xml文件时,要把&转为其本身的转义字符配置properties文件的urlurl=jdbc:mysql:///ds3?useSSL=false&serverTimezone=UTC配置xml文件的url<property name="url">jdbc:mysql://localhost:3306/ds3?useSSL=false&serverTimezone=UTC</property>
1、java连接MySQL数据库需要有一个驱动jar包
例如:mysql-connector-java-5.1.26-bin.jar,
该驱动jar可以自行百度搜索最新包下载放在项目的lib目录下即可。
2、连接代码如下
package baidu.test.jsp
import java.sql.Connection
import java.sql.DriverManager
import java.sql.ResultSet
import java.sql.SQLException
import java.sql.Statement
import javax.naming.spi.DirStateFactory.Result
public class DbConnection {
private static Connection conn
public DbConnection() {
String drivername="com.mysql.jdbc.Driver"
String username="root"
String url="jdbc:mysql://localhost/jsptest?useUnicode=true&characterEncoding=UTF-8"
String password=""
//加载驱动
try {
Class.forName(drivername)
} catch (ClassNotFoundException e) {
System.out.println("驱动加载失败!")
e.printStackTrace()
}
//建立连接
try {
conn=DriverManager.getConnection(url,username,password)
} catch (SQLException e) {
System.out.println("数据库连接失败!")
e.printStackTrace()
}
}
//getResultSet
public ResultSet GetResultSet(String sql)
{
ResultSet rs=null
//statemanage
try {
Statement st=conn.createStatement()
rs=st.executeQuery(sql)
} catch (SQLException e) {
System.out.println("状态管理器创建失败")
e.printStackTrace()
}
return rs
}
//DML
public int DML(String sql)
{
int count=-1
try {
Statement statement=conn.createStatement()
count=statement.executeUpdate(sql)
} catch (SQLException e) {
System.out.println("状态管理器创建失败")
e.printStackTrace()
}
return count
}
}
3、可以新建service类来调用连接类里面的getResultSet方法和DML,实现自己所需用的功能。
两行log4j:WARN 只是警告,log4j没有正确的配置。。
Loading class `com.mysql.jdbc.Driver'. 这一行 把driverclassname 由"com.mysql.jdbc.Driver"改成"com.mysql.cj.jdbc.Driver"。
评论列表(0条)