如何使用PreparedStatement减少开发时间?
如何使用PreparedStatement减少开发时间?
JDBC(Java Database Connectivity,java数据库连接)的API中的主要的四个类之一的java。sql。Statement要求开发者付出大量的时间和精力。在使用Statement获取JDBC访问时所具有的一个共通的问题是输入适当格式的日期和时间戳个PreparedStatement是从java。
sql。Connection对象和所提供的SQL字符串得到的,SQL字符串中包含问号(?),这些问号标明变量的位置,然后提供变量的值,最后执行语句,例如:Stringsql = "SELECT * FROM People p WHERE p。
id = ? AND p。name = ?";PreparedStatement ps = connection。prepareStatement(sql);ps。setInt(1,id);ps。setString(2,name);ResultSet rs = ps。
execute(); 使用PreparedStatement的另一个优点是字符串不是动态创建的。下面是一个动态创建字符串的例子: Stringsql = "SELECT * FROM People p WHERE p。i = "+id; 这允许JVM(JavaVirtual Machine,Java虚拟机)和驱动/数据库缓存语句和字符串并提高性能。
PreparedStatement也提供数据库无关性。当显示声明的SQL越少,那么潜在的SQL语句的数据库依赖性就越小。
答:PreparedStatement对象并不需要SQL语句作为参数提供给这些方法,因为它们已经包含预编译SQL语句详情>>