當前位置:首頁 » 編程軟體 » mysql開啟預編譯

mysql開啟預編譯

發布時間: 2024-06-16 19:07:58

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這個預編譯功能才有意義。

熱點內容
php重命名文件夾 發布:2024-11-26 19:06:01 瀏覽:18
阿里雲ecs伺服器無法連接公網ip 發布:2024-11-26 19:01:32 瀏覽:42
java寫helloworld 發布:2024-11-26 19:00:56 瀏覽:89
c語言遞歸排列 發布:2024-11-26 18:50:55 瀏覽:448
密碼鎖為什麼不建議用南孚 發布:2024-11-26 18:45:00 瀏覽:153
榮耀20s安卓版本在哪裡看 發布:2024-11-26 18:26:03 瀏覽:685
安卓手機前攝像頭進灰怎麼清理 發布:2024-11-26 18:23:08 瀏覽:173
kettlejava腳本 發布:2024-11-26 18:05:07 瀏覽:455
c語言關機命令 發布:2024-11-26 17:59:56 瀏覽:901
wmi文件夾 發布:2024-11-26 17:55:55 瀏覽:534