mysql开启预编译
1. idea数据库怎么写查找内容
根据id查询数据库中的一个内容:
1.连接数据库
2.编写带?的sql语句
3.预编译
4.填充占位符
5.执行操作
6.if判断是否有值,打印输出
7.关闭驱动
示例:
package cn.kgc.crud;
import cn.kgc.entity.User;
import cn.kgc.util.JDBCUtil;
import java.sql.*;/**
* Created by helloworld on 2020/6/24.
* 根据id查询一个数据 */public class SelectUserById { public static void main(String[] args){
Connection connection=null;
PreparedStatement pstm=null;
ResultSet rs=null; try { //1连接数据库
Class.forName("com.mysql.jdbc.Driver"); // 使用的技术:数据库名://ip:mysql端口/数据库名字
connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/xxx", "rxxx", "xxxxx") //2.编写?sql
String sql ="select * from user where id=?"; //3.预编译
pstm = connection.prepareStatement(sql); //4.填充占位符
pstm.setObject(1,"1"); //5.执行
rs = pstm.executeQuery(); //6判断是否有值,然后打印
if(rs.next()){ /*int id = rs.getInt(1);
String name = rs.getString(2);
int age = rs.getInt(3);*/
int id = rs.getInt("id");
String name = rs.getString("name"); int age = rs.getInt("age");
User user = new User(id,name,age);
System.out.println(user.toString()); // System.out.println("id:"+id+",name:"+name+",age"+age);
}
} catch (SQLException e) {
e.printStackTrace();
}finally { //7.关闭
JDBCUtil.closeResource2(rs,pstm,connection);
}
}
}
2. php 使用mysql 的prepare预编译,下面这段代码有防sql注入的功能么请高手赐教
sql注入怎么回事:说白了就是在一个单引号上做文章,你把单引号转义就没啥问题了,预编译就是把这些字符转义后插入,其中包括单引号。
这段可以防止.
3. mysql 有没有 类似PRO*C或者esql的 预编译器
这种程序需要先使用数据库编程软件的编译器编译生成.c文件后,才可以再使用C编译器对.c文件进行编译。比如Oracle的ProC和informix的ESQL/C。 建议查看一下ProC和ESQL/C方面的资料。
4. mysql 预编译 为什么默认不开启
mysql 预编译 为什么默认不开启
当然如果开启预编译功能的话,还要开启客户端缓存功能,否则有害无利。但是即使开了预编译功能也不会对程序带来多大改进,因为mysql的服务端预编译是session级别的,也就是说除非你的单个connection 进行了大量的重复某个SQL这个预编译功能才有意义。
5. mysql怎么实现预编译
玩Oracle的都比较关注shared pool,特别是library cache,在使用了绑定变量(预编译sql)之后确实能得到很大的性能提升。现在在转Mysql之后特别是innodb很多东西都还能和Oracle对得上号的,就像innodb_buffer_pool_size类似于Oracle的database buffer cache,innodb_log_buffer_size类似于redo log buffer,但是innodb_additional_mem_pool_size仅仅类似于shared pool的Data dictionary cache,似乎还缺少和library cache相对应的东西。那就有一个问题了,在Mysql里面使用预编译的sql还会有性能提升吗?
这里我用Java的jdbc做了一下测试,分别用Statement和PreparedStatement执行1000个sql,并运行10次
1.使用Statement做硬解析:
结果如下:
elapsed time(ms):14773
elapsed time(ms):16352
elapsed time(ms):14797
elapsed time(ms):15800
elapsed time(ms):12069
elapsed time(ms):14953
elapsed time(ms):13238
elapsed time(ms):12366
elapsed time(ms):15263
elapsed time(ms):13089
average time(ms):14270
可以看出两种方式执行的结果几乎相同,不像Oracle差距那么大。而且就算是用PreparedStatement的方式,在Mysql数据库端抓出来的sql语句也不是以变量id=?的形式出现的,而是实际的数值。后来在网上看到在连接字符串上加上useServerPrepStmts=true可以实现真正的预编译
String url="jdbc:mysql://172.16.2.7:3306/testdb"; url=url+"?useServerPrepStmts=true";
加上这段后可以在数据库端可以看到明确的结果:
mysql> show global status like 'Com_stmt_prepare';
+------------------+-------+
| Variable_name | Value |
+------------------+-------+
| Com_stmt_prepare | 11 |
+------------------+-------+
1 row in set (0.00 sec)
但是实际的运行结果和上面几乎一样,性能上也没有任何的提升。由此可以推断出Mysql由于缺少类似于Oracle的library cache的部件,因此采用预编译方式执行sql是没有性能上的提升的。
6. jdbc链接MySql数据库,预编译的sql语句怎么使用批处理执行
是指应用程序的方法吧。如果你是用hibernate、iBATIS等连接数据库,直接从log4j配置文件中打开调试模式就行,如果用的自己写的jdbc连接,那就只能在执行前打印了
7. 如何关闭mysql指定功能的预编译功能
如何关闭mysql指定功能的预编译功能
当然如果开启预编译功能的话,还要开启客户端缓存功能,否则有害无利。但是即使开了预编译功能也不会对程序带来多大改进,因为mysql的服务端预编译是session级别的,也就是说除非你的单个connection 进行了大量的重复某个SQL这个预编译功能才有意义。