JDBC:实现Java与数据库的连接
先了解重要的编程思想:ORM(object relational mapping)
即将数据库与JAVA的类一一映射(对应)
- 一个数据表对应一个Java类
- 表中的一条记录对应Java类的一个对象
- 表中的一个字段对应Java类的一个属性
写代码之前的准备工作:
1.要加依赖包(mysql依赖包)
2.IDEA也要连接数据库
将连接数据库的基本信息都放在配置文件中,我们通过读取配置文件的方式,来获取和数据库的连接。
那么这样做有什么好处?
- 实现解耦,数据与代码分离。如果之后想换数据库/换账号密码,直接在配置文件中改就可以了,清晰简单。
- 如果需要修改配置文件的信息,可以避免程序重新再打包。
⬇️基本JDBC连接数据库的代码,可以直接复用
public void testConnection() throws Exception{
//1.读取基本信息
InputStream is = ConnectionTest.class.getClassLoader().getResource();
Properties pros = new Properties();
pros.load(is);
//这些参数都写在配置文件(pom.xml) 里,读取就可以了
String user = pros.getProperty("user");
String password = pros.getProperty("password");
String url = pros.getProperty("url");
String driverClass = pros.getProperty("driverClass");
//2.然后再加载驱动(注册驱动)
Class.forName(driverClass);
//3.再获取一个连接
Connection conn = DriverManager.getConnection(url,user,password);
//4.好了可以写sql语句了,这里用?来代表占位符,?位置的内容之后再填写
String sql = "insert into customers(name,email,birth)values(?,?,?)";
PreparedStatement ps = conn.prepareStatement();
//5.要开始解决 ? 了 ———— 开始填东西
ps.setString(1,"xx");
ps.setString(2,"xxxx@email.com");
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
java.util.Date date = sdf.parse("2002-08-01");
ps.setDate(3,new Date(date.getTime()));
//6.都写好了就可以执行啦,可以把返回的结果都放到结果集中
ResultSet rs = ps.executeQuery();
//7.查完了,别忘记关闭连接,然后释放资源(很重要!)
ps.close();
conn.close();
}
⬆️没加 try 和 catch 和 finally 的代码
如果单纯使用Statement,会产生弊端:存在SQL注入的问题。
解决方式:使用PreparedStatement
就可以了
JAVA与SQL对应数据类型转换表
Java | SQL |
---|---|
boolean. | BIT |
byte | TINYINT |
short | SMALLINT |
int | INTEGER |
long | BIGINT |
String | CHAR,VARCHAR,LONGVARCHAR |
byte array | BINARY, VAR BINARY |
java.sql.Date | DATE |
java.sql.Time | TIME |
java.sql.Timestamp | TIMESTAMP |
两种技术
JDBC结果集的元数据:ResultSetMetaData
获取列数:getColumnCount();
获取列的别名:getColumnLabel();
如果考虑事务
public void test() throws Exception(){
//……
//前面老样子,就省略不写了,但有个重要的!
//我们要先取消对事务的自动提交(想想SQL)
conn.setAutoCommit(false);
//好了接下来写2个sql语句,模拟一下这是事务
String sql1;
String sql2;
//那么现在有2个sql语句要执行,一起执行后……
update(conn,sql1,"A");
update(conn,sql2,"B");
//最后再提交,此时前面2个语句肯定都是成功执行了,那么这样就是完成一个事务了
conn.commit();
//这样就可以保证都执行完了再提交了
//记得关资源
JDBCUtiles.closeResource(conn,ps);
}
ps: 如果有异常,就用rollback()回滚事务