java JDBC编程学习笔记
- JDBC 简介
- 什么是JDBC
- JDBC的简单写法
- 笔记
- 简单例子
- JDBC封装
- 笔记
- 封装的例子
- Properties工具
- util类
- main类
JDBC 简介
什么是JDBC
JDBC(Java DataBase Connectivity)就是Java数据库连接,顾名思义,就是用Java语言来操作数据库。原来我们操作数据库是在数据库的可视化界面使用SQL语句来操作数据库,JDBC是用Java语言向数据库发送SQL语句。
关于JDBC的原理和其他相关的介绍推荐这位博主的文章:
JDBC的简单写法
我总结了一些写法:
笔记
1.建立一个连接connection
例:con= DriverManager.getConnection(url,user,password);
url的写法:url="jdbc:mysql://主机地址:端口号/数据库名称?统一字符集&字符编码&加密连接";
例:url="jdbc:mysql://localhost:3306/study?useUnicode=true&characterEncoding=utf8&useSSL=true";
2.获得类的对象
Class.forName("com.mysql.cj.jdbc.Driver");//这里可能会有些问题,如果有出现问题换成com.mysql.jdbc.Driver
3.写SQL语句 例:String sql="sql语句";
4.创建一个声明:statement st;
st=con.createStatement();
5.创建一个结果集:ResultSet re;
re=st.executeUpdate(sql);//插入、更新、删除都用executeUpdate,查询用executeQuery;
做完笔记就要上手写一写,这样才会熟练!
简单例子
package mysql;
import java.sql.*;
public class Query{
public static void main(String[] args) {
Connection con=null;
Statement st=null;
ResultSet re=null;
String url="jdbc:mysql://localhost:3306/study?useUnicode=true&characterEncoding=utf8&useSSL=true";
String sql="select * from selectCourse where studentName like '庄%'";
try {
Class.forName("com.mysql.cj.jdbc.Driver");
con= DriverManager.getConnection(url,"root","root");
st=con.createStatement();
re=st.executeQuery(sql);
while (re.next()){
String s1=re.getString(1);
String s2=re.getString(2);
String s3=re.getString(3);
String s4=re.getString(4);
System.out.print(s1);
System.out.print(" "+s2);
System.out.print(" "+s3);
System.out.println(" "+s4);
}
} catch (ClassNotFoundException | SQLException e) {
e.printStackTrace();
}finally {
if (re!=null){
try {
re.close();
} catch (SQLException throwable) {
throwable.printStackTrace();
}
}
if (st!=null){
try {
st.close();
} catch (SQLException throwable) {
throwable.printStackTrace();
}
}
if (con!=null){
try {
con.close();
} catch (SQLException throwable) {
throwable.printStackTrace();
}
}
}
}
}
这样子就是一个简单的例子:通过java向指定的数据库查询数据。如果我们要写一个两个这种代码还可以这样写,但如果我们要通过java写大量这样子的增删改查代码的话,有一些语句都是重复的就会很浪费人力物力,所以我们考虑把那些重复不变的代码封装成一个工具类,这样子写一次就行了。
JDBC封装
笔记
可以将一些相同的代码自己封装成一个工具类:
把driver,url,username,password封装在properties;
例:driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/study?useUnicode=true&characterEncoding=utf8&useSSL=true
username=root
password=root
然后建一个uitl类
在类中通过流的方式获取properties里面的资源
InputStream in =jdbcUtil.class.getClassLoader().getResourceAsStream("db.properties");
Properties properties=new Properties();
properties.load(in);
driver=properties.getProperty("driver");
url=properties.getProperty("url");
username=properties.getProperty("username");
password=properties.getProperty("password");
Class.forName(driver);
将资源连接和资源释放分别封装成两个方法
1.getConnection()
2.release(Connection conn, Statement st, ResultSet rs)
测试类:
conn= 工具类.资源连接方法();//获取数据库连接
st= conn.createStatement();//获取SQL的执行对象
String sql="SQL语句";
st.executeUpdate(sql);//插入、更新、删除都用executeUpdate,查询用executeQuery;
然后在finally调用资源释放方法jdbcUtil.release(conn,st,rs);
笔记做好,上手↓
封装的例子
Properties工具
driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/study?useUnicode=true&characterEncoding=utf8&useSSL=true
username=root
password=root
util类
package studykuang.utils;
import java.io.InputStream;
import java.sql.*;
import java.util.Properties;
public class jdbcUtil {
private static String driver=null;
private static String url=null;
private static String username=null;
private static String password=null;
static {
try {
InputStream in = jdbcUtil.class.getClassLoader().getResourceAsStream("db.properties");
Properties properties=new Properties();
properties.load(in);
driver=properties.getProperty("driver");
url=properties.getProperty("url");
username=properties.getProperty("username");
password=properties.getProperty("password");
Class.forName(driver);
} catch (Exception e) {
e.printStackTrace();
}
}
//资源连接方法
public static Connection getConnection() throws SQLException {
return DriverManager.getConnection(url, username, password);
}
//资源连接释放
public static void release(Connection conn, Statement st, ResultSet rs) {
if (rs!=null){
try {
rs.close();
} catch (SQLException throwable) {
throwable.printStackTrace();
}
}
if (st!=null){
try {
st.close();
} catch (SQLException throwable) {
throwable.printStackTrace();
}
}
if (conn!=null){
try {
conn.close();
} catch (SQLException throwable) {
throwable.printStackTrace();
}
}
}
}
main类
这个类需要改动的也只是SQL语句和执行条件
package studykuang;
import studykuang.utils.jdbcUtil;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class TestInsert {
public static void main(String[] args) {
Connection conn=null;
Statement st=null;
ResultSet rs=null;
try {
conn= jdbcUtil.getConnection();//获取数据库连接
st= conn.createStatement();//获取SQL的执行对象
String sql="INSERT INTO student(studentNo,studentName,studentAge,Specialty)" +
"VALUES('1009','YJL',35,'basketball')";
int i = st.executeUpdate(sql);
if (i>0){
System.out.println("数据插入成功!");
}
} catch (SQLException throwable) {
throwable.printStackTrace();
}finally {
jdbcUtil.release(conn,st,rs);//如果rs没有返回值,填null也是OK
}
}
}
在例子中我提到com.mysql.cj.jdbc.Driver(com.mysql.jdbc.Driver)这个问题,这个跟我们所用的mysql-connector-java的版本有关。具体讲解推荐这篇文章:
本篇文章到这就结束了。每次在网上看视频,都会做一些笔记,如果各位有好的做笔记方式方法可以跟我交流交流,共同进步;如果这篇文章有可以优化的地方希望大佬指教指教。