JDBC连接数据库

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();
    }
}

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SherlockerSun

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值