mysql數據庫預編譯,數據庫預編譯原理

本文目錄一覽:

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做硬解析:

1 package exmysql; 2  3 import java.sql.Connection; 4 import java.sql.DriverManager; 5 import java.sql.ResultSet; 6 import java.sql.SQLException; 7 import java.sql.Statement; 8 import java.util.Date; 9 10 public class adddata {11     12     private static long worker(){13         Date begin = new Date();

14         15         String driver=”com.mysql.jdbc.Driver”;16 17         String url=”jdbc:mysql://172.16.2.7:3306/testdb”;18         19         Connection conn=null;20         Statement stmt=null;21         ResultSet rs=null;22         23         try{24             Class.forName(driver);25             conn=DriverManager.getConnection(url,”dbaadmin”,”123456″);26             stmt=conn.createStatement();27             String sql;28             for (int i=1;i=5000;i++){29                 sql=”select * from test1 where id=”+i;30                 rs=stmt.executeQuery(sql);31             }32         }33         catch(SQLException | ClassNotFoundException e){34             e.printStackTrace();35         }36         37         if(stmt!=null){38             try{39                 stmt.close();40             }41             catch(SQLException e){42                 e.printStackTrace();43             }44         }45         46         if(conn!=null){47             try{48                 conn.close();49             }50             catch(SQLException e){51                 e.printStackTrace();52             }53         }54         55         Date end = new Date();

56         return end.getTime()-begin.getTime();57     }58 59     public static void main(String[] args) {60         // TODO Auto-generated method stub61         62         long elapsed,average;63         average=0;64         for (int i=1;i=10;i++){65             elapsed=worker();66             System.out.println(“elapsed time(ms):”+elapsed);67             average=average+elapsed;68         }69         System.out.println(“average time(ms):”+average/10);70     }71 72 }

結果如下:

elapsed time(ms):24652

elapsed time(ms):13380

elapsed time(ms):13250

elapsed time(ms):13877

elapsed time(ms):13275

elapsed time(ms):13193

elapsed time(ms):19022

elapsed time(ms):13558

elapsed time(ms):14138

elapsed time(ms):13364

average time(ms):15170

2.同樣的sql用PreparedStatement預編譯執行

1 package exmysql; 2  3 import java.sql.*; 4 import java.util.Date; 5  6 public class insert_data { 7  8     private static long worker(){ 9         Date begin = new Date();

10         11         String driver=”com.mysql.jdbc.Driver”;12 13         String url=”jdbc:mysql://172.16.2.7:3306/testdb”;14         15         Connection conn=null;16         PreparedStatement pstm=null;17         ResultSet rs=null;18         19         try{20             Class.forName(driver);21             conn=DriverManager.getConnection(url,”dbaadmin”,”123456″);22             String sql=”select * from test1 where id=?”;24             pstm=conn.prepareStatement(sql);25             for(int i=1;i=5000;i++){26                 pstm.setInt(1, i);27                 rs=pstm.executeQuery();28             }29             31         }32         catch(SQLException | ClassNotFoundException e){33             e.printStackTrace();34         }35         36         if(pstm!=null){37             try{38                 pstm.close();39             }40             catch(SQLException e){41                 e.printStackTrace();42             }43         }44         45         if(conn!=null){46             try{47                 conn.close();48             }49             catch(SQLException e){50                 e.printStackTrace();51             }52         }53         54         Date end = new Date();

55         return end.getTime()-begin.getTime();56     }57     58     public static void main(String[] args) {59         // TODO Auto-generated method stub60         61         long elapsed,average;62         average=0;63         for (int i=1;i=10;i++){64             elapsed=worker();65             System.out.println(“elapsed time(ms):”+elapsed);66             average=average+elapsed;67         }68         System.out.println(“average time(ms):”+average/10);69     }70 71 }

結果如下:

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是沒有性能上的提升的。

mysql 預編譯 為什麼默認不開啟

mysql 預編譯 為什麼默認不開啟

當然如果開啟預編譯功能的話,還要開啟客戶端緩存功能,否則有害無利。但是即使開了預編譯功能也不會對程序帶來多大改進,因為mysql的服務端預編譯是session級別的,也就是說除非你的單個connection 進行了大量的重複某個SQL這個預編譯功能才有意義。

mysql 5.5.54 不支持 預編譯嗎

mysql 5.5.54 支持 預編譯

開始安裝mysql

1.1 創建用戶和組

groupadd mysql

useradd mysql -s /sbin/nologin -M -g mysql

1.2 解壓編譯MySQL

cd /root/tools

tar zxf mysql-5.5.32.tar.gz

cd mysql-5.5.32

#圖一

cmake . -DCMAKE_INSTALL_PREFIX=/application/mysql-5.5.32 \

-DMYSQL_DATADIR=/application/mysql-5.5.32/data \

-DMYSQL_UNIX_ADDR=/application/mysql-5.5.32/tmp/mysql.sock \

-DDEFAULT_CHARSET=utf8 \

-DDEFAULT_COLLATION=utf8_general_ci \

-DEXTRA_CHARSETS=gbk,gb2312,utf8,ascii \

-DENABLED_LOCAL_INFILE=ON \

-DWITH_INNOBASE_STORAGE_ENGINE=1 \

-DWITH_FEDERATED_STORAGE_ENGINE=1 \

-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \

-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 \

-DWITHOUT_PARTITION_STORAGE_ENGINE=1 \

-DWITH_FAST_MUTEXES=1 \

-DWITH_ZLIB=bundled \

-DENABLED_LOCAL_INFILE=1 \

-DWITH_READLINE=1 \

-DWITH_EMBEDDED_SERVER=1 \

-DWITH_DEBUG=0

#圖二

make make install

#圖三

3

1.3添加鏈接

ln -s /application/mysql-5.5.32/ /application/mysql

原創文章,作者:FGAW,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/131481.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
FGAW的頭像FGAW
上一篇 2024-10-03 23:45
下一篇 2024-10-03 23:45

相關推薦

  • 如何修改mysql的端口號

    本文將介紹如何修改mysql的端口號,方便開發者根據實際需求配置對應端口號。 一、為什麼需要修改mysql端口號 默認情況下,mysql使用的端口號是3306。在某些情況下,我們需…

    編程 2025-04-29
  • Python 常用數據庫有哪些?

    在Python編程中,數據庫是不可或缺的一部分。隨着互聯網應用的不斷擴大,處理海量數據已成為一種趨勢。Python有許多成熟的數據庫管理系統,接下來我們將從多個方面介紹Python…

    編程 2025-04-29
  • openeuler安裝數據庫方案

    本文將介紹在openeuler操作系統中安裝數據庫的方案,並提供代碼示例。 一、安裝MariaDB 下面介紹如何在openeuler中安裝MariaDB。 1、更新軟件源 sudo…

    編程 2025-04-29
  • Harris角點檢測算法原理與實現

    本文將從多個方面對Harris角點檢測算法進行詳細的闡述,包括算法原理、實現步驟、代碼實現等。 一、Harris角點檢測算法原理 Harris角點檢測算法是一種經典的計算機視覺算法…

    編程 2025-04-29
  • 瘦臉算法 Python 原理與實現

    本文將從多個方面詳細闡述瘦臉算法 Python 實現的原理和方法,包括該算法的意義、流程、代碼實現、優化等內容。 一、算法意義 隨着科技的發展,瘦臉算法已經成為了人們修圖中不可缺少…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL數據庫 在使用Python操作MySQL之前,我們需要先連接MySQL數據庫。在Python中,我…

    編程 2025-04-29
  • 數據庫第三範式會有刪除插入異常

    如果沒有正確設計數據庫,第三範式可能導致刪除和插入異常。以下是詳細解釋: 一、什麼是第三範式和範式理論? 範式理論是關係數據庫中的一個規範化過程。第三範式是範式理論中的一種常見形式…

    編程 2025-04-29
  • 神經網絡BP算法原理

    本文將從多個方面對神經網絡BP算法原理進行詳細闡述,並給出完整的代碼示例。 一、BP算法簡介 BP算法是一種常用的神經網絡訓練算法,其全稱為反向傳播算法。BP算法的基本思想是通過正…

    編程 2025-04-29
  • MySQL遞歸函數的用法

    本文將從多個方面對MySQL遞歸函數的用法做詳細的闡述,包括函數的定義、使用方法、示例及注意事項。 一、遞歸函數的定義 遞歸函數是指在函數內部調用自身的函數。MySQL提供了CRE…

    編程 2025-04-29
  • leveldb和unqlite:兩個高性能的數據庫存儲引擎

    本文將介紹兩款高性能的數據庫存儲引擎:leveldb和unqlite,並從多個方面對它們進行詳細的闡述。 一、leveldb:輕量級的鍵值存儲引擎 1、leveldb概述: lev…

    編程 2025-04-28

發表回復

登錄後才能評論