解释代码//删除图书 public int bookDelete(Connection con, String id) throws Exception { String sql = "delete from t_book where id=?"; PreparedStatement pstmt = con.prepareStatement(sql); pstmt.setString(1, id); return pstmt.executeUpdate(); }
时间: 2024-03-11 13:44:39 浏览: 55
这段代码是一个在数据库中删除图书数据的方法,主要包括以下几个步骤:
1. 定义 SQL 语句:通过字符串拼接的方式定义 SQL 语句,其中使用了占位符 "?"。
2. 创建 PreparedStatement 对象:通过 Connection 对象的 prepareStatement 方法创建 PreparedStatement 对象,该对象可以执行 SQL 语句。
3. 设置参数:通过 PreparedStatement 对象的 setString 方法设置 SQL 语句中的占位符 "?" 的值,这里将图书的 id 作为参数传入。
4. 执行 SQL 语句:通过 PreparedStatement 对象的 executeUpdate 方法执行 SQL 语句,该方法返回被修改的记录行数。
5. 返回结果:将被修改的记录行数作为方法的返回值返回。
需要注意的是,在使用完 PreparedStatement 对象后需要手动关闭该对象以释放资源。
相关问题
解释代码 // 还书 public int bookReturn(Connection con, String bookName) throws Exception { String sql = "update t_book set state=? where bookname=?"; PreparedStatement pstmt = con.prepareStatement(sql); pstmt.setInt(1, 0); pstmt.setString(2, bookName); return pstmt.executeUpdate(); }
这段代码是一个在数据库中更新图书状态的方法,主要包括以下几个步骤:
1. 定义 SQL 语句:通过字符串拼接的方式定义 SQL 语句,其中使用了占位符 "?"。
2. 创建 PreparedStatement 对象:通过 Connection 对象的 prepareStatement 方法创建 PreparedStatement 对象,该对象可以执行 SQL 语句。
3. 设置参数:通过 PreparedStatement 对象的 setInt 和 setString 方法设置 SQL 语句中的占位符 "?" 的值,这里将图书的状态设置为 0(0 表示未借出),将图书的名称作为参数传入。
4. 执行 SQL 语句:通过 PreparedStatement 对象的 executeUpdate 方法执行 SQL 语句,该方法返回被修改的记录行数。
5. 返回结果:将被修改的记录行数作为方法的返回值返回。
需要注意的是,在使用完 PreparedStatement 对象后需要手动关闭该对象以释放资源。该方法的作用是将指定书名的图书状态设置为未借出(即状态码设为 0)。
public int add(Connection con,SchoolClass schoolClass)throws Exception{ String sql="insert into t_school_class values(null,?,?)"; PreparedStatement pstmt=con.prepareStatement(sql); pstmt.setString(1, schoolClass.getClassName()); System.out.println(schoolClass.getClassName()); pstmt.setString(2, schoolClass.getCalssDesc()); return pstmt.executeUpdate(); } /** * 查询班级集合 * @param con * @param schoolClass * @return * @throws Exception */ public ResultSet list(Connection con,SchoolClass schoolClass)throws Exception{ StringBuffer sb=new StringBuffer("select * from t_school_class"); if(StringUtil.isNotEmpty(schoolClass.getClassName())){ sb.append(" and className like '%"+schoolClass.getClassName()+"%'"); } PreparedStatement pstmt=con.prepareStatement(sb.toString().replaceFirst("and", "where")); return pstmt.executeQuery(); } /** * 删除班级 * @param con * @param id * @return * @throws Exception */ public int delete(Connection con,String id)throws Exception{ String sql="delete from t_school_class where id=?"; PreparedStatement pstmt=con.prepareStatement(sql); pstmt.setString(1, id); return pstmt.executeUpdate(); } /** * 更新班级 * @param con * @param schoolClass * @return * @throws Exception */ public int update(Connection con,SchoolClass schoolClass)throws Exception{ String sql="update t_school_class set className=?,classDesc=? where id=?"; PreparedStatement pstmt=con.prepareStatement(sql); pstmt.setString(1, schoolClass.getClassName()); pstmt.setString(2, schoolClass.getCalssDesc()); pstmt.setInt(3, schoolClass.getId()); return pstmt.executeUpdate(); } }
这段代码看起来像是一个 Java 类中的一些数据库操作方法,这些方法分别是添加班级、查询班级集合、删除班级和更新班级信息。这些方法都需要一个数据库连接对象 Connection 和一个 SchoolClass 类型的参数。其中,添加班级方法使用了 PreparedStatement 预编译 SQL 语句,查询班级集合方法使用了 StringBuffer 拼接 SQL 语句,并使用了 StringUtil 工具类的方法判断字符串是否为空,删除班级方法使用了 PreparedStatement 预编译 SQL 语句并传入一个 ID 参数,更新班级信息方法同样使用了 PreparedStatement 预编译 SQL 语句,并传入一个 SchoolClass 对象的参数。
阅读全文