JDBC连接数据库
原创
©著作权归作者所有:来自51CTO博客作者SherlockerSun的原创作品,请联系作者获取转载授权,否则将追究法律责任
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();
}
}