首頁 資料庫 mysql教程 sql update更新不同字段类型性能分析

sql update更新不同字段类型性能分析

Jun 07, 2016 pm 05:51 PM
性能分析

MySQL在使用update更新数据时,如果条件字段的类型为数字型,但参数是字符型的而且该条件又匹配不到记录,就会引起严重的性能问题

。如下:

 代码如下 复制代码
1,update test007 set key1 = key1 + '1' where id = 200000;
2,update test007 set key1 = key1 + '1' where id = '200000';

注意上面查询语句区别在于参数的类型不同,前者为数字型,后者为字符型,同时id为200000这条记录是不存在的。

如果使用第二条查询,而且满足记录不存在,这条查询将出现严重的效率问题,测试情况如下:

二,测试实践
1,创建一张测试数据表test007

 代码如下 复制代码
CREATE TABLE `test007` (                                  
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,          
`key1` int(10) NOT NULL DEFAULT '0',                 
`key2` int(10) NOT NULL DEFAULT '0',                 
`key3` int(10) NOT NULL DEFAULT '0',                    
PRIMARY KEY (`id`)                                                        
) ENGINE=MyISAM AUTO_INCREMENT=0 DEFAULT CHARSET=gbk

2,创建测试数据

 代码如下 复制代码


$db = _connect("localhost","root","");
mysql__db("test");
set_time_limit(0);
$table = 'test007';
for($i=0;$i     $k1 = rand(10000,300000);
    $k2 = rand(0,3);
    $k3 = rand(1,100000);
    mysql_query("insert into $table (key1,key2,key3) values ('".$k1."','".$k2."','".$k3."')",$db);
}
?>


说明:创建1000000(100W)条记录,数据大小为16.2 MB

3,测试参数类型为数字型的情况

 代码如下 复制代码

mysql> update test007 set key1=key1+'1' where id=10000001;
Query OK, 0 rows affected (0.00 sec)
Rows matched: 0  Changed: 0  Warnings: 0

查询语句的性能情况
+----------------------+----------+
| Status               | Duration |
+----------------------+----------+
| starting             | 0.000104 |
| checking permissions | 0.000005 |
| Opening tables       | 0.000010 |
| System lock          | 0.013440 |
| Table lock           | 0.000004 |
| init                 | 0.000035 |
| Updating             | 0.000020 |
| end                  | 0.000034 |
| query end            | 0.000002 |
| freeing items        | 0.000028 |
| logging slow query   | 0.000001 |
| cleaning up          | 0.000005 |
+----------------------+----------+
12 rows in set (0.00 sec)

说明:主键id的字段类型为数字型

4,测试参数类型为字符型的情况

 代码如下 复制代码

mysql> update test007 set key1=key1+'1' where id='100000001';
Query OK, 0 rows affected (0.03 sec)
Rows matched: 0  Changed: 0  Warnings: 0

查询语句的性能情况
+----------------------+----------+
| Status               | Duration |
+----------------------+----------+
| starting             | 0.000108 |
| checking permissions | 0.000005 |
| Opening tables       | 0.029382 |
| System lock          | 0.000003 |
| Table lock           | 0.000003 |
| init                 | 0.000039 |
| Updating             | 0.000074 |
| end                  | 0.000022 |
| query end            | 0.000002 |
| freeing items        | 0.000033 |
| logging slow query   | 0.000001 |
| cleaning up          | 0.000001 |
+----------------------+----------+
12 rows in set (0.00 sec)

在使用UPDATE更新记录时,如果被更新的字段的类型和所赋的值不匹配时,MySQL将这个值转换为相应类型的值。如果这个字段是数值类型,而且所赋值超 过了这个数据类型的最大范围,那么MySQL就将这个值转换为这个范围最大或最小值。如果字符串太长,MySQL就将多余的字符串截去。如果设置非空字段 为空,那么将这个字段设置为它们的默认值,数字的默认值是0,字符串的默认值是空串(不是null,是"")。

由于测试环境数据量比较小,所以测试的结果不明显,但关键是在开发过程中一定要注意字段类型与参数类型的一致性,避免在特定情况下造成数据在更新和删除过程中的额外开销。

5,测试大数据量的情况,过程如下

 代码如下 复制代码

第一步:创建数据表
CREATE TABLE `test008` (                                  
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,          
`key1` int(10) NOT NULL DEFAULT '0',                 
`key2` text,                 
`key3` int(10) NOT NULL DEFAULT '0',                    
PRIMARY KEY (`id`)                                                        
) ENGINE=MyISAM AUTO_INCREMENT=0 DEFAULT CHARSET=gbk

第二步:创建测试数据
创建1000000(100W)条记录,数据大小为2.07 GB (2,224,000,000 字节)

第三步:两条查询性能比较
mysql> update test008 set key1=key1+'1' where id='100000001';
Query OK, 0 rows affected (0.03 sec)
Rows matched: 0  Changed: 0  Warnings: 0

mysql> update test008 set key1=key1+'1' where id=100000001;
Query OK, 0 rows affected (0.00 sec)
Rows matched: 0  Changed: 0  Warnings: 0

第四步:创建索引
mysql> alter table test008 add index key3 (key3);
Query OK, 1000000 rows affected (5 min 54.33 sec)
Records: 1000000  Duplicates: 0  Warnings: 0

第五步:测试不同的条件
mysql> update test008 set key1 = key1 + '1' where id='';
Query OK, 0 rows affected (0.01 sec)
Rows matched: 0  Changed: 0  Warnings: 0

mysql> update test008 set key1 = key1 + '1' where id='12321232123';
Query OK, 0 rows affected (44.58 sec)
Rows matched: 0  Changed: 0  Warnings: 0

mysql> update test008 set key1 = key1 + '1' where id=12321232123;
Query OK, 0 rows affected (0.00 sec)
Rows matched: 0  Changed: 0  Warnings: 0

mysql> update test008 set key1= key1+ '1' where id='test';
Query OK, 0 rows affected (0.00 sec)
Rows matched: 0  Changed: 0  Warnings: 0

注意:上面测试中部分条件已经超出id字段的范围

 

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

麒麟8000與驍龍處理器效能分析:細數強弱對比 麒麟8000與驍龍處理器效能分析:細數強弱對比 Mar 24, 2024 pm 06:09 PM

麒麟8000與驍龍處理器效能分析:細數強弱對比隨著智慧型手機的普及和功能不斷增強,處理器作為手機的核心組件也備受關注。目前市面上最常見且性能優異的處理器品牌之一就是華為的麒麟系列和高通的驍龍系列。本文將圍繞麒麟8000和驍龍處理器展開效能分析,探討兩者在各方面的強弱對比。首先,讓我們來了解一下麒麟8000處理器。作為華為公司最新推出的旗艦處理器,麒麟8000

如何使用php擴充XDebug進行強大的調試和效能分析 如何使用php擴充XDebug進行強大的調試和效能分析 Jul 28, 2023 pm 07:45 PM

如何使用PHP擴展Xdebug進行強大的調試和效能分析引言:在開發PHP應用程式的過程中,調試和效能分析是必不可少的環節。而Xdebug是PHP開發者常用的一款強大的調試工具,它提供了一系列進階功能,如斷點調試、變數追蹤、效能分析等。本文將介紹如何使用Xdebug進行強大的除錯和效能分析,以及一些實用的技巧和注意事項。一、安裝Xdebug在開始使用Xdebu

效能比較:Go語言與C語言的速度與效率 效能比較:Go語言與C語言的速度與效率 Mar 10, 2024 pm 02:30 PM

效能比較:Go語言與C語言的速度與效率在電腦程式設計領域,效能一直是開發者關注的重要指標。在選擇程式語言時,開發者通常會注意其速度和效率。 Go語言和C語言作為兩種流行的程式語言,被廣泛用於系統級程式設計和高效能應用。本文將比較Go語言和C語言在速度和效率方面的表現,並透過具體的程式碼範例來展示它們之間的差異。首先,我們來看看Go語言和C語言的概況。 Go語言是由G

如何進行C++程式碼的效能分析? 如何進行C++程式碼的效能分析? Nov 02, 2023 pm 02:36 PM

如何進行C++程式碼的效能分析?在開發C++程式時,效能是一個重要的考量。優化程式碼的效能可以提高程式的運行速度和效率。然而,想要優化程式碼,首先需要了解它的效能瓶頸在哪裡。而要找到效能瓶頸,首先需要進行程式碼的效能分析。本文將介紹一些常用的C++程式碼效能分析工具和技術,幫助開發者找到程式碼中的效能瓶頸,以便進行最佳化。使用Profiling工具Profiling工

Laravel開發:如何使用Laravel Telescope進行效能分析與監控? Laravel開發:如何使用Laravel Telescope進行效能分析與監控? Jun 13, 2023 pm 05:14 PM

Laravel開發:如何使用LaravelTelescope進行效能分析與監控? Laravel是一款優秀的PHP框架,由於其簡單易用和靈活性而備受開發者喜愛。為了更好地監控和分析Laravel應用程式的效能,Laravel團隊開發了一個名為Telescope的強大工具。在本文中,我們將介紹Telescope的一些基本使用方法和功能。安裝Telescope在

對Java Queue佇列效能的分析與最佳化策略 對Java Queue佇列效能的分析與最佳化策略 Jan 09, 2024 pm 05:02 PM

JavaQueue佇列的效能分析與最佳化策略摘要:佇列(Queue)是Java中常用的資料結構之一,廣泛應用於各種場景。本文將從效能分析和最佳化策略兩個面向來探討JavaQueue佇列的效能問題,並給出具體的程式碼範例。引言佇列是一種先進先出(FIFO)的資料結構,可用來實作生產者-消費者模式、執行緒池任務佇列等場景。 Java提供了多種佇列的實現,例如Arr

C++開發建議:如何進行C++程式碼的效能分析 C++開發建議:如何進行C++程式碼的效能分析 Nov 22, 2023 pm 08:25 PM

身為C++開發人員,效能最佳化是我們不可避免的任務之一。為了提高程式碼的執行效率和回應速度,我們需要了解C++程式碼的效能分析方法,以便更好地調試和優化程式碼。在本文中,我們將為您介紹一些常用的C++程式碼效能分析工具和技術。編譯選項C++編譯器提供了一些編譯選項,可以用來最佳化程式碼的執行效率。其中,最常用的選項為-O,它可以告訴編譯器進行程式碼最佳化。通常,我們會設定

如何使用效能分析工具對 Java 函數進行分析與最佳化? 如何使用效能分析工具對 Java 函數進行分析與最佳化? Apr 29, 2024 pm 03:15 PM

Java效能分析工具可用於分析和最佳化Java函數的效能。選擇效能分析工具:JVisualVM、VisualVM、JavaFlightRecorder(JFR)等。配置效能分析工具:設定採樣率、啟用事件。執行函數並收集資料:啟用分析工具後執行函數。分析效能數據:辨識CPU使用率、記憶體使用率、執行時間、熱點等瓶頸指標。最佳化函數:使用最佳化演算法、重構程式碼、使用快取等技術提高效率。

See all articles