1:jdbc介绍如果没有JDBC,Java程序员需要面向各个数据库驱动接口编程,开发复杂 ; sun公司提供一套统一JDBC接口规范,Java程序只需要使用JDBC就可以操作任何数据库,JDBC实现类由各个数据库厂商提供. 2:常用类说明1:DriverManager操作数据库第一步是需要注册驱动, DriverManager类的目的:注册驱动和获取连接的 Class.forName("com.mysql.jdbc.Driver"); - 代码是固定的 需导入驱动包 2:JDBC URL说明mysql为例: 需要获取连接数据库的相关协议: jdbc:mysql://localhost:3306/dbname-操作数据库的名字 jdbc:mysql://127.0.0.1:3306/dbname 这里 jdbc: 是JDBC连接协议 这里 mysql:// 是mysql数据库连接协议,JDBC子协议 localhost:3306 主机和端口, dbname 数据库名 3:Connection 连接通过驱动管理器(DriverManager)可以获取链接,操作数据库必须要先获取链接 获得SQL的操作对象 Statement conn.createStatement() PreparedStatement conn.prepareStatement(sql) 该对象可以将SQL发送给数据库进行执行 4:Statement用于将SQL 发送给数据库 获得操作结果 executeUpdate 用于向数据库发送 insert update delete语句,返回int 类型参数,代表影响记录行数 executeQuery 用于向数据库发送 select 语句,返回ResultSet 结果集对象 execute 用于数据库发送任何SQL语句 返回boolean ,SQL执行结果是ResultSet 返回true,否则 false 5:ResultSetResultSet包含符合 SQL 语句中条件的所有行,并且它通过一套 get 方法(这些 get 方法可以访问当前行中的不同列)提供了对这些行中数据的访问。ResultSet.next方法用于移动到 ResultSet 中的下一行,使下一行成为当前行。 结果集一般是一个表,其中有查询所返回的列标题及相应的值。 行: ResultSet 维护指向其当前数据行的光标。每调用一次 next 方法,光标向下移动一行。 最初它位于第一行之前,因此第一次调用 next 将把光标置于第一行上,使它成为当前行。随着每次调用 next 导致光标向下移动一行,按照从上至下的次序获取ResultSet行。 列: 方法getXXX 提供了获取当前行中某列值的途径。在每一行内,可按任何次序获取列值。但为了保证可移植性,应该从左至右获取列值。也可以通过列名来获取值。 3:使用步骤1:加载驱动 2:创建连接 3:连接数据库 4:编写sql 5:创建执行对象 6:执行sql语句 7:释放资源 动态新增数据 通过对象传递值 4:结果集处理1:数据结果集只有一条记录一般采用: if(rs.next()){ //查到了数据 }else{ //没有查到数据 } 2: 如果是多条记录采用循环遍历 while(rs.next()){ // 根据数据库内部 列类型,选择相应getXXX方法 int ---- getInt() varchar ---- getString() date ----- getDate() } 5:抽取工具类每一个类中都需要写重复的代码,而且一旦数据库发生变化的话,就需要修改所有的代码,此时可以抽取为工具类 |
|