SQL预编译

预编译与执行存储过程

prepare myfun from 'select * from a where b = ?';
set @str = '测试';
execute myfun using @str;

SQL预编译是一种数据库操作技术,它将SQL语句的编译和执行过程分离。在执行SQL语句时,先将SQL语句发送到数据库服务器进行编译,生成执行计划,这个编译后的执行计划会被缓存起来。之后,当再次执行相同结构的SQL语句时,只需将不同的参数传递给该执行计划,而不需要重新编译SQL语句,从而提高了数据库操作的效率和安全性。 在JDBC中,有客户端预编译和服务器端预编译之分,对应的URL配置项是`useServerPrepStmts`。当`useServerPrepStmts`为`false`时使用客户端(驱动包内完成SQL转义)预编译,`useServerPrepStmts`为`true`时使用数据库服务器端预编译[^2]。 以下是一个JDBC预编译的示例代码: ```java public class PrepareSQL { public static void main(String[] args) throws SQLException { // 数据库连接信息,开启预编译功能 String url = "jdbc:mysql:///db_test?useSSL=false&useServerPrepStmts=true"; String username = "root"; String password = "root"; // 获取Connection java.sql.Connection connection = java.sql.DriverManager.getConnection(url, username, password); // 编写sql语句,用?占位符表示参数 String sql = "select * from tb_user where username=? and password=?"; // 获取预编译执行 java.sql.PreparedStatement preparedStatement = connection.prepareStatement(sql); // 设置sql参数,用的是index,从1开始,表示第一个? preparedStatement.setString(1, "zhangsan"); preparedStatement.setString(2, "456"); // 执行sql,得到结果集合 java.sql.ResultSet resultSet = preparedStatement.executeQuery(); System.out.println(resultSet); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值