?写在前面?
📢今天我们进行 JDBC 获取数据库连接的5种方式 的学习,感谢你的阅读,内容若有不当之处,希望大家多多指正,一起进步💯!!! ??如果觉得博主文章还不错,可以👍三连支持?一下哦😀
??JDBC 获取数据库连接的5种方式
🍀JDBC程序编写步骤
1.注册驱动 - - -加载Driver类 2.获取连接 - - -得到Connection 3.执行sql语句 - - -发送sql给MySQL执行 4.释放资源 - - -关闭相关连接
🍃准备工作
导入mysql-connection-java-8.0.28.jar第三方jar包(如果mysql是5.7版本导入相对性的版本)
在项目目录下创建目录libs,并将上述jar包复制到该目录下
右键jar包,点击Add As Library…
点击OK
🌿方式一
@Test
public void test01() throws SQLException {
Driver driver = new Driver();
String url = "jdbc:mysql://localhost:3306/java2022";
Properties properties = new Properties();
properties.setProperty("user", "root");
properties.setProperty("password", "111111");
Connection connect = driver.connect(url, properties);
String sql = "delete from student where SID = 7";
Statement statement = connect.createStatement();
int i = statement.executeUpdate(sql);
System.out.println(i > 0 ? "操作成功" : "操作失败");
connect.close();
statement.close();
}
🍁 解读
1.注册驱动 - - -加载Driver类 创建driver对象 2.获取连接 - - -得到Connection 3.执行sql语句 - - -发送sql给MySQL执行 statement 用于执行静态 SQL 语句并返回其生成的结果的对象 4.释放资源 - - -关闭相关连接
🌳方式二
方式一 是直接通过new的方式创建com.mysql.cj.jdbc.Driver() 对象(如果是mysql5.0版本使用的是com.mysql.jdbc.Driver(),这里是mysql8.0版本),属于是静态加载,灵活性差,依赖性强。 方式二 使用反射加载Driver类,动态加载,更加的灵活,减少依赖性
@Test
public void test02() throws ClassNotFoundException, IllegalAccessException, InstantiationException, SQLException {
Class<?> aClass = Class.forName("com.mysql.cj.jdbc.Driver");
Driver driver = (Driver) aClass.newInstance();
String url = "jdbc:mysql://localhost:3306/java2022";
Properties properties = new Properties();
properties.setProperty("user", "root");
properties.setProperty("password", "111111");
Connection connect = driver.connect(url, properties);
Statement statement = connect.createStatement();
String sql = "insert into student values(7,'王昭君',19,'女')";
int i = statement.executeUpdate(sql);
System.out.println(i > 0 ? "操作成功" : "操作失败");
connect.close();
statement.close();
}
🌴方式三
方式三 使用DriverManager替换Driver
@Test
public void test03() throws ClassNotFoundException, IllegalAccessException, InstantiationException, SQLException {
Class<?> aClass = Class.forName("com.mysql.cj.jdbc.Driver");
Driver driver = (Driver) aClass.newInstance();
String url = "jdbc:mysql://localhost:3306/java2022";
String user = "root";
String password = "111111";
DriverManager.registerDriver(driver);
Connection connection = DriverManager.getConnection(url, user, password);
Statement statement = connection.createStatement();
String sql = "insert into student values(8,'吕布',20,'男')";
int i = statement.executeUpdate(sql);
System.out.println(i > 0 ? "操作成功" : "操作失败");
connection.close();
statement.close();
}
🌵方式四
方式四 使用 Class.forName自动完成注册驱动, 简化代码,推荐使用。 在代码中没有指明注册驱动也可以获取数据数据连接,这是因为在加载Driver类时,为我们自动完成了注册驱动。
@Test
public void test04() throws ClassNotFoundException, IllegalAccessException, InstantiationException, SQLException {
Class<?> aClass = Class.forName("com.mysql.cj.jdbc.Driver");
Driver driver = (Driver)aClass.newInstance();
String url = "jdbc:mysql://localhost:3306/java2022";
String user = "root";
String password = "111111";
Connection connection = DriverManager.getConnection(url, user, password);
Statement statement = connection.createStatement();
String sql = "insert into student values(9,'赵云',18,'男')";
int i = statement.executeUpdate(sql);
System.out.println();
System.out.println(i > 0 ? "操作成功" : "操作失败");
connection.close();
statement.close();
}
🌾方式五
方式五 在方式四的基础上增加配置文件, 让连接 mysql 更加灵活。
@Test
public void test05() throws IOException, ClassNotFoundException, SQLException {
Properties properties = new Properties();
properties.load(new FileInputStream("src\\mysql.properties"));
String driver = properties.getProperty("driver");
String url = properties.getProperty("url");
String user = properties.getProperty("user");
String password = properties.getProperty("password");
Class.forName(driver);
Connection connection = DriverManager.getConnection(url, user, password);
String sql = "insert into student values(10,'廉颇',18,'男')";
int i = connection.createStatement().executeUpdate(sql);
System.out.println(i > 0 ? "操作成功" : "操作失败");
connection.close();
statement.close();
}
🌱补充说明
1.MySQL驱动5.1.6及以后无需再使用Class.forName(“com.mysql.cj.jdbc.Driver”); 2.从jdk1.5以后使用了jdbc4,不再需要显示调用class.forName() 注册而是自动调用驱动jar包下META-INF\services\java.sql.Driver文本中的类名称去注册。
3.建议写上Class.forName(“com.mysql.cj.jdbc.Driver”); ,更加明确,防止低版本兼容问题。
|