idea连接jdbc
1.导入jar包
2.注册驱动
Class.forName(“com.mysql.jdbc.Driver”);
3.获取连接
Connection con = DriverManager.getConnection(“jdbc:mysql:/ /localhost:3306/db”,“root”,123456);
4.获取执行者对象
Statement stat = con.createStatement0;
5.执行sql语句,并接收返回结果
String sql =“SELECT * FROM user”;
ResultSet rs = stat.executeQuery(sql);
6.处理结果
while(rs.next()) {
System.out.println(rs.getInt(“id”) +"\t + rs.getstring(“name”);
}
7.释放资源 后执行先释放
con.close();
stat.close();
rs.close();
jdbc各功能详解
1.DriverManager
● DriverManager:驱动管理对象
● 注册驱动(告诉程序该使用哪一个数据库驱动)
● static void registerDriver(Driver driver):注册与给定的驱动程序 DriverManager
● 写代码使用:Class.forName(“com.mysql.jdbc.Driver”);
● 通过查看源码发现:在com.mysql.jdbc.Driver类中存在静态代码块
static {
try {
java.sql.DriverManager.registerDriver(new Driver());
} catch (SQLException E) {
throw new RuntimeException(“Can’t register driver!”);
}
● }
● 注意:mysql5之后的驱动jar包可以省略注册驱动的步骤。在jar包中,存在一个java.sql.Driver配置文件,文件中指定了com.mysql.jdbc.Driver
● 获取数据库连接(获取到数据库的连接并返回连接对象)
● static Connection getConnection(String url, String user, String password);
● 返回值:Connection数据库连接对象
● 参数
● url:指定连接的路径。语法:jdbc:mysql://ip地址(域名):端口号/数据库名称
● user:用户名
● password:密码
2.Connection
● Connection:数据库连接对象
● 获取执行者对象
● 获取普通执行者对象:Statement createStatement();
● 获取预编译执行者对象:PreparedStatement prepareStatement(String sql);
● 管理事务
● 开启事务:setAutoCommit(boolean autoCommit); 参数为false,则开启事务。
● 提交事务:commit();
● 回滚事务:rollback();
● 释放资源
● 立即将数据库连接对象释放:void close();
3.Statement
● Statement:执行sql语句的对象
● 执行DML语句:int executeUpdate(String sql);
● 返回值int:返回影响的行数。
● 参数sql:可以执行insert、update、delete语句。
● 执行DQL语句:ResultSet executeQuery(String sql);
● 返回值ResultSet:封装查询的结果。
● 参数sql:可以执行select语句。
● 释放资源
● 立即将执行者对象释放:void close();
4.ResultSet
● ResultSet:结果集对象
● 判断结果集中是否还有数据:boolean next();
● 有数据返回true,并将索引向下移动一行
● 没有数据返回false
● 获取结果集中的数据:XXX getXxx(“列名”);
● XXX代表数据类型(要获取某列数据,这一列的数据类型)
● 例如:String getString(“name”); int getInt(“age”);
● 释放资源
● 立即将结果集对象释放:void close();