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();
}
posted @ 2022-02-05 00:02  姚同学今天写代码了吗  阅读(87)  评论(0编辑  收藏  举报