发布时间:2019-09-02 07:42:39编辑:auto阅读(1552)
接口 | 作用 |
---|---|
Statement接口 | 用于执行静态的sql语句 |
PreparedStatement接口 | 用于执行预编译sql语句 |
CallableStatement接口 | 用于执行存储过程的sql语句(call xxx) |
序号 | 不同 | 描述 |
---|---|---|
1 | 语法不同 | PreparedStatement可以使用预编译的sql,而Statement只能使用静态的sql |
2 | 效率不同 | PreparedStatement可以使用sql缓存区,效率比Statement高 |
3 | 安全性不同 | PreparedStatement可以有效防止sql注入,而Statement不能防止sql注入。 |
package com.rk.db.c_prepared; import java.sql.Connection; import java.sql.SQLException; import java.sql.PreparedStatement; import com.rk.db.utils.JDBCUtil; /** * 使用PreparedStatement执行Insert语句 * @author RK */ public class Demo01 { public static void main(String[] args) { Connection conn = null; PreparedStatement pstmt = null; try { //1.获取连接 conn = JDBCUtil.getConnection(); //2.准备预编译的sql String sql = "INSERT INTO T_Persons(UserName,Pwd) VALUES(?,?)"; //3.执行预编译sql语句(检查语法) pstmt = conn.prepareStatement(sql); //4.设置参数值: 参数位置 从1开始 pstmt.setString(1, "地球人"); pstmt.setString(2, "987"); //5.发送参数,执行sql int count = pstmt.executeUpdate(); System.out.println("影响了"+count+"行!"); } catch (SQLException e) { e.printStackTrace(); } finally { //关闭资源 JDBCUtil.close(conn, pstmt, null); } } }
package com.rk.db.c_prepared; import java.sql.Connection; import java.sql.SQLException; import java.sql.PreparedStatement; import com.rk.db.utils.JDBCUtil; /** * 使用PreparedStatement执行Update语句 * @author RK */ public class Demo02 { public static void main(String[] args) { Connection conn = null; PreparedStatement pstmt = null; try { //1.获取连接 conn = JDBCUtil.getConnection(); //2.准备预编译的sql String sql = "UPDATE T_Persons SET UserName=?, Pwd=? WHERE Id=?"; //3.执行预编译sql语句(检查语法) pstmt = conn.prepareStatement(sql); //4.设置参数值: 参数位置 从1开始 pstmt.setString(1, "火星人"); pstmt.setString(2, "456"); pstmt.setInt(3, 5); //5.发送参数,执行sql int count = pstmt.executeUpdate(); System.out.println("影响了"+count+"行!"); } catch (SQLException e) { e.printStackTrace(); } finally { //关闭资源 JDBCUtil.close(conn, pstmt, null); } } }
package com.rk.db.c_prepared; import java.sql.Connection; import java.sql.SQLException; import java.sql.PreparedStatement; import com.rk.db.utils.JDBCUtil; /** * 使用PreparedStatement执行Delete语句 * @author RK */ public class Demo03 { public static void main(String[] args) { Connection conn = null; PreparedStatement pstmt = null; try { //1.获取连接 conn = JDBCUtil.getConnection(); //2.准备预编译的sql String sql = "DELETE FROM T_Persons WHERE Id=?"; //3.执行预编译sql语句(检查语法) pstmt = conn.prepareStatement(sql); //4.设置参数值: 参数位置 从1开始 pstmt.setInt(1, 5); //5.发送参数,执行sql int count = pstmt.executeUpdate(); System.out.println("影响了"+count+"行!"); } catch (SQLException e) { e.printStackTrace(); } finally { //关闭资源 JDBCUtil.close(conn, pstmt, null); } } }
package com.rk.db.c_prepared; import java.sql.Connection; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.PreparedStatement; import com.rk.db.utils.JDBCUtil; /** * 使用PreparedStatement执行Select语句 * @author RK */ public class Demo04 { public static void main(String[] args) { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; try { //1.获取连接 conn = JDBCUtil.getConnection(); //2.准备预编译的sql String sql = "SELECT * FROM T_Persons"; //3.执行预编译sql语句(检查语法) pstmt = conn.prepareStatement(sql); //4.执行sql语句,得到返回结果 rs = pstmt.executeQuery(); //5.输出 while(rs.next()) { int id = rs.getInt("Id"); String userName = rs.getString("UserName"); String pwd = rs.getString("Pwd"); System.out.println(id + "\t" + userName + "\t" + pwd); } } catch (SQLException e) { e.printStackTrace(); } finally { //关闭资源 JDBCUtil.close(conn, pstmt, rs); } } }
上一篇: error while loading
下一篇: 6.简单sql注入之3
47867
46433
37321
34767
29336
25999
24952
19970
19568
18056
5810°
6436°
5953°
5978°
7083°
5928°
5969°
6461°
6425°
7803°