1. 什么是JDBC
JDBC(Java Database Connection),sun公司为开发者使用数据库提供的一组编程接口,再由各大数据库厂商来实现编程类(JDBC驱动程序)
2. JDBC访问数据库流程
- 加载驱动
装载MySql驱动:Class.ForName("com.mysql.jdbc.Driver");
驱动程序内部是Socket来实现业务
- 建立连接
建立MySql数据库连接:DriverManager.getConnection("jdbc:mysql://localhost:3306/数据库名", "账号", "密码");
此处连接的是本地数据库,若要连接其他的数据库,则把localhost改成IP地址,如果mysql没做改动的话,默认是使用3306端口
DriverManager是Sun公司的一个接口,由厂商实现。
Java和数据库通过Socket来实现通信,是一个远程连接。比较耗时!
- 发送SQL查询
1. 使用Statement
execute()
executeQuery():用于select查询语句,查询到可以获得一个返回集
executeUpdate():用于insert、delete、update,返回成功执行的条数
因为statement在使用的时候sql语句中含有变量时,需采用拼字符串的方式,所有有可能出现sql注入的风险
2. 使用PreparedStatement
String sql = "insert into t_user (username, pwd, regTime) values(?, ?, ?)"; // 变量使用?作为占位符
PreparedStatement ps = conn.preparedStatement(sql);
ps.setObject(1, "Sam"); // 偏移地址从1开始,使用setObject可以不用区分要插入的对象类型,系统自动转换
ps.execute(); 执行
- 得到查询结果
ResultSet rs = stmt.executeQuery();
使用while循环去读取结果,返回结果集默认指向第一个数据之前,next()方法将指针下移一个,若存在数据则返回真,此时rs.getString(x),rs.getInt(x)等方法可以读取改行数据,x指向当前行的第x列,取出来的数据类型需和方法名对应。若不存在下一条数据则返回假。
while(rs.next())
{
}