import java.sql.DriverManagerimport java.sql.ResultSetimport java.sql.SQLExceptionimport java.sql.Connectionimport java.sql.Statement public class MysqlDemo {public static void main(String[] args) throws Exception {Connection conn = null String sql // MySQL的JDBC URL编写方式:jdbc:mysql://主机名称:连接端口/
数据库的名称?参数=值// 避免中文乱码要指定useUnicode和characterEncoding// 执行数据库 *** 作之前要在数据库管理系统上创建一个数据库,名字自己定,// 下面
语句之前就要先创建javademo数据库String url = "jdbc:mysql://localhost:3306/javademo?"+ "user=root&password=root&useUnicode=true&characterEncoding=UTF8" try {// 之所以要使用下面这条语句,是因为要使用MySQL的驱动,所以我们要把它驱动起来,//
可以通过Class.forName把它加载进去,也可以通过初始化来驱动起来,下面三种形式都可以Class.forName("com.mysql.jdbc.Driver")// 动态加载mysql驱动// or:// com.mysql.jdbc.Driver driver = new com.mysql.jdbc.Driver() // or:// new com.mysql.jdbc.Driver() System.out.println("成功加载MySQL驱动程序") // 一个Connection代表一个数据库连接conn = DriverManager.getConnection(url) // Statement里面带有很多方法,比如executeUpdate可以实现插入,更新和删除等Statement stmt = conn.createStatement() sql = "create table student(NO char(20),name varchar(20),primary key(NO))" int result = stmt.executeUpdate(sql)// executeUpdate语句会返回一个受影响的行数,如果返回-1就没有成功if (result != -1) {System.out.println("创建数据表成功") sql = "insert into student(NO,name) values('2012001','陶伟基')" result = stmt.executeUpdate(sql) sql = "insert into student(NO,name) values('2012002','周小俊')" result = stmt.executeUpdate(sql) sql = "select * from student" ResultSet rs = stmt.executeQuery(sql)// executeQuery会返回结果的集合,否则返回空值System.out.println("学号\t姓名") while (rs.next()) {System.out.println(rs.getString(1) + "\t" + rs.getString(2))// 入如果返回的是int类型可以用getInt()}}} catch (SQLException e) {System.out.println("MySQL *** 作错误") e.printStackTrace() } catch (Exception e) {e.printStackTrace() } finally {conn.close() } } }
spring 常用 dataSource 配置如下:
而 driver-class-name 的 com.mysql.jdbc.Driver 与 com.mysql.cj.jdbc.Driver 有什么区别呢?
当5之后的版本选择 com.mysql.jdbc.Driver 的时候,会有警告提示,替换为 com.mysql.cj.jdbc.Drive
查看源码可知,老版本的 Driver 继承了新版本的 Driver ,通过继承的方式兼容老版本,并添加了告警提示,如下:
评论列表(0条)