1.MySQL
public class jdbcTest {
    private static final String URL = "jdbc:mysql://localhost:3306/jdbc?serverTimezone=UTC&characterEncoding=utf-8&useUnicode=true";
    private static final String USER = "root";
    private static final String PASSWORD = "123456";
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
		/*1.注册驱动(3种方法),依赖于驱动jar包的存在,否则无法通过编译
		DriverManager.registerDriver(new com.mysql.jdbc.Driver());*/
		//方法2:System.setProperties("jdbc.drivers","com.mysql.jdbc.Driver");
		//方法3:*****推荐使用******
		Class.forName("com.mysql.jdbc.Driver");	
		//2.建立连接
		Connection conn=DriverManager.getConnection(URL, USER, PASSWORD);
		//3.创建语句执行对象
		String sql="select * from user";
		Statement st=conn.prepareStatement(sql);//使用Statement对象,prepareStatement防止sql注入
		//4.执行语句
		ResultSet rs=st.executeQuery(sql);
		//5.处理结果
		while(rs.next()){
			System.out.print(rs.getObject(1)+"\t"+rs.getObject(2)+"\t"+rs.getObject(3)+"\t");
		}
		//6.释放资源,资源rs、st、conn的释放顺序与创建顺序相反
		rs.close();
		st.close();
		conn.close();
    }
}
2.HikariDataSource
@SpringBootTest
public class DataSourceTests {//is a Object
    /**
     * 在项目中添加了数据库相关依赖以后,springboot底层会自动帮我们配置一个
     * 数据源(DataSource)对象,此对象是连接池的规范.
     * @Autowired注解描述属性时,是告诉spring框架,要基于反射机制为属性赋值(依赖注入)
     * 赋值时,首先会基于属性类型从spring容器查找相匹配的对象, 假如只有一个则直接注入,
     * 有多个相同类型的对象时,还会比较属性名(检测属性名是否与bean名字相同),有相同的
     * 则直接注入(没有相同的直接抛出异常.)
     */
    @Autowired
    private DataSource dataSource;//HikariDataSource (类)

    @Test //org.junit.jupiter.api.Test
    void testGetConnection() throws SQLException {
        //获取链接时,会基于dataSource获取连接池对象,进而从池中获取连接
        Connection conn=dataSource.getConnection();
        System.out.println("conn="+conn);
    }
    @Test
    void testSaveNotice() throws SQLException {//homework (通过此方法基于jdbc向数据库写入一条数据)
        //1.建立连接
        Connection conn=dataSource.getConnection();
        //2.创建statement
        String sql="insert into user (username,password) values ('u3',666)";
        Statement st=conn.prepareStatement(sql);//防止sql注入
        //3.发送sql
        boolean rs= st.execute(sql);
        //4.处理结果
        if (rs){
            System.out.println("添加失败");
        }
        System.out.println("添加成功");
        //5.释放资源
        st.close();
        conn.close();
    }
}