我們先來看下面試題:
面試題:如何判斷SQL查詢操作是不是慢sql、如何優(yōu)化(阿里面試題)
面試題:MySQL慢查詢開啟,語句分析(阿里面試題)
(學(xué)習(xí)視頻分享:java教學(xué)視頻)
一、開啟mysql慢查詢
方式一:修改配置文件
在 my.ini 增加幾行:
[mysqlld] //定義查過多少秒的查詢算是慢查詢,我這里定義的是2秒 long_query_time=2 #5.0、5.1等版本配置如下選項 log-slow-queries="mysql_slow_query.log" #5.5及以上版本配置如下選項 slow-query-log=On slow_query_log_file="mysql_slow_query.log" //記錄下沒有使用索引的query log-query-not-using-indexes
(相關(guān)學(xué)習(xí)視頻分享:java面試題及答案)
方式二:通過MySQL數(shù)據(jù)庫開啟慢查詢
mysql>set global slow_query_log=ON mysql>set global long_query_time = 3600; mysql>set global log_querise_not_using_indexes = ON;
二、執(zhí)行一次慢查詢操作
其實想要執(zhí)行一次有實際意義的慢查詢比較困難,因為在自己測試的時候,就算查詢有20萬條數(shù)據(jù)的海量表,也只需要0.幾秒。我們可以通過如下語句代替:
SELECT SLEEP(10);
三、查看慢查詢的數(shù)量
通過如下sql語句,來查看一共執(zhí)行過幾次慢查詢:
show global status like '%slow%';
四、分析慢查詢?nèi)罩?/p>
方式一:通過工具分析
MySQL自帶了mysqldumpslow工具用來分析slow query日志,除此之外,還有一些好用的開源工具。
這里假設(shè)保存的日志名為long.log
列出記錄次數(shù)最多的10個sql語句:
mysqldumpslow -s c -t 10 long.log
列出返回記錄集最多的10個sql語句:
mysqldumpslow -s r -t 10 long.log
方式二:直接分析mysql慢查詢?nèi)罩?/p>
# Time: 121017 17:38:54 # User@Host: root[root] @ localhost [127.0.0.1] # Query_time: 3.794217 Lock_time: 0.000000 Rows_sent: 1 Rows_examined: 4194304 SET timestamp=1350466734; select * from wei where text='orange'; # Time: 121017 17:46:22 # User@Host: root[root] @ localhost [127.0.0.1] # Query_time: 3.819219 Lock_time: 0.000000 Rows_sent: 0 Rows_examined: 4194304 SET timestamp=1350467182; select * from wei where text='long';
相關(guān)推薦:java入門教程
Atas ialah kandungan terperinci java面試——慢查詢. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Untuk mengendalikan transaksi JDBC dengan betul, anda mesti terlebih dahulu mematikan mod komit automatik, kemudian melakukan pelbagai operasi, dan akhirnya melakukan atau mengembalikan semula hasilnya; 1. Panggil Conn.SetAutOcommit (palsu) untuk memulakan transaksi; 2. Melaksanakan pelbagai operasi SQL, seperti memasukkan dan mengemaskini; 3. Panggil Conn.Commit () jika semua operasi berjaya, dan hubungi conn.rollback () jika pengecualian berlaku untuk memastikan konsistensi data; Pada masa yang sama, cuba-dengan-sumber harus digunakan untuk menguruskan sumber, mengendalikan pengecualian dengan betul dan menutup sambungan untuk mengelakkan kebocoran sambungan; Di samping itu, adalah disyorkan untuk menggunakan kolam sambungan dan menetapkan mata simpan untuk mencapai rollback separa, dan menyimpan urus niaga sesingkat mungkin untuk meningkatkan prestasi.

Pra-formancetartuptimemoryusage, quarkusandmicronautleadduetocompile-timeprocessingandgraalvsupport, withquarkusoftenperforminglightbetterine serverless scenarios.tyvelopecosyste,

HTTP Log Middleware di GO boleh merakam kaedah permintaan, laluan, IP klien dan memakan masa. 1. Gunakan http.handlerfunc untuk membungkus pemproses, 2. Rekod waktu mula dan masa akhir sebelum dan selepas memanggil next.servehttp, 3. Dapatkan IP pelanggan sebenar melalui r.remoteaddr dan X-forward-for headers, 4. Gunakan log.printf untuk mengeluarkan log permintaan, 5. Kod sampel lengkap telah disahkan untuk dijalankan dan sesuai untuk memulakan projek kecil dan sederhana. Cadangan lanjutan termasuk menangkap kod status, menyokong log JSON dan meminta penjejakan ID.

Koleksi Sampah Java (GC) adalah mekanisme yang secara automatik menguruskan ingatan, yang mengurangkan risiko kebocoran ingatan dengan menuntut semula objek yang tidak dapat dicapai. 1.GC menghakimi kebolehcapaian objek dari objek akar (seperti pembolehubah stack, benang aktif, medan statik, dan lain -lain), dan objek yang tidak dapat dicapai ditandakan sebagai sampah. 2. Berdasarkan algoritma penandaan tanda, tandakan semua objek yang dapat dicapai dan objek yang tidak ditandai. 3. Mengamalkan strategi pengumpulan generasi: Generasi Baru (Eden, S0, S1) sering melaksanakan MinorGC; Orang tua melakukan kurang tetapi mengambil masa lebih lama untuk melakukan MajorGC; Metaspace Stores Metadata kelas. 4. JVM menyediakan pelbagai peranti GC: SerialGC sesuai untuk aplikasi kecil; ParallelGC meningkatkan throughput; CMS mengurangkan

Memilih jenis htmlinput yang betul dapat meningkatkan ketepatan data, meningkatkan pengalaman pengguna, dan meningkatkan kebolehgunaan. 1. Pilih jenis input yang sepadan mengikut jenis data, seperti teks, e -mel, tel, nombor dan tarikh, yang secara automatik boleh menyemak dan menyesuaikan diri dengan papan kekunci; 2. Gunakan HTML5 untuk menambah jenis baru seperti URL, Warna, Julat dan Carian, yang dapat memberikan kaedah interaksi yang lebih intuitif; 3. Gunakan pemegang tempat dan sifat -sifat yang diperlukan untuk meningkatkan kecekapan dan ketepatan pengisian bentuk, tetapi harus diperhatikan bahawa pemegang tempat tidak dapat menggantikan label.

GradleisthebetterChoiceFormostNewProjectSduetoitSsuperiorflexibility, Prestasi, danModernToolingSupport.1.Gradle'sGroovy/KOT lindslismoreconciseandexpressivethanmaven'sverbosexml.2.GradleOutPerformsMaveninBuildSpeedWithIncrementalcompilation, BuildCac

Jawapan yang jelas untuk soalan ini adalah cadangan untuk melaksanakan corak pemerhati menggunakan antara muka pemerhati tersuai. 1. Walaupun Java menyediakan pemerhati dan pemerhati, bekas adalah kelas dan telah ditetapkan dan tidak mempunyai fleksibiliti; 2. Amalan yang disyorkan moden adalah untuk menentukan antara muka pemerhati yang berfungsi, dan subjek mengekalkan senarai pemerhati dan memberitahu semua pemerhati apabila keadaan berubah; 3. Ia boleh digunakan dalam kombinasi dengan ungkapan lambda untuk meningkatkan kesederhanaan dan mengekalkan kod; 4. Bagi senario GUI atau Javabean, PropertyChangeListener boleh digunakan. Oleh itu, projek-projek baru harus mengguna pakai skim antara muka pemerhati tersuai, yang selamat, mudah diuji dan mengkhususkan diri dalam java moden

Menggunakan perpustakaan OpencSV adalah pilihan terbaik untuk membaca fail CSV. Ia boleh mengendalikan situasi yang kompleks dan menyokong pelbagai ciri; 2. Untuk fail CSV yang mudah, anda boleh menggunakan bufferedreader terbina dalam Java yang digabungkan dengan kaedah perpecahan; 3. Jika anda memerlukan kawalan format yang lebih fleksibel atau telah menggunakan komponen Apache, anda boleh memilih Apache Commonscsv. OpenCSV disyorkan untuk kesederhanaan, keteguhan dan keupayaan untuk menangani masalah CSV dalam senario sebenar.
