Maison base de données tutoriel 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字段的范围

 

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Analyse des performances des processeurs Kirin 8000 et Snapdragon : comparaison détaillée des forces et des faiblesses Analyse des performances des processeurs Kirin 8000 et Snapdragon : comparaison détaillée des forces et des faiblesses Mar 24, 2024 pm 06:09 PM

Analyse des performances des processeurs Kirin 8000 et Snapdragon : comparaison détaillée des forces et des faiblesses Avec la popularité des smartphones et leurs fonctionnalités croissantes, les processeurs, en tant que composants essentiels des téléphones mobiles, ont également attiré beaucoup d'attention. L'une des marques de processeurs les plus courantes et les plus excellentes sur le marché est actuellement la série Kirin de Huawei et la série Snapdragon de Qualcomm. Cet article se concentrera sur l'analyse des performances des processeurs Kirin 8000 et Snapdragon et explorera la comparaison des forces et des faiblesses des deux sous divers aspects. Jetons d’abord un coup d’œil au processeur Kirin 8000. En tant que dernier processeur phare de Huawei, le Kirin 8000

Comparaison des performances : rapidité et efficacité du langage Go et du langage C Comparaison des performances : rapidité et efficacité du langage Go et du langage C Mar 10, 2024 pm 02:30 PM

Comparaison des performances : rapidité et efficacité du langage Go et du langage C Dans le domaine de la programmation informatique, les performances ont toujours été un indicateur important auquel les développeurs prêtent attention. Lors du choix d'un langage de programmation, les développeurs se concentrent généralement sur sa rapidité et son efficacité. Le langage Go et le langage C, en tant que deux langages de programmation populaires, sont largement utilisés pour la programmation au niveau système et les applications hautes performances. Cet article comparera les performances du langage Go et du langage C en termes de vitesse et d'efficacité, et démontrera les différences entre eux à travers des exemples de code spécifiques. Tout d’abord, jetons un coup d’œil à la présentation du langage Go et du langage C. Le langage Go est développé par G

Comment utiliser l'extension php XDebug pour un débogage puissant et une analyse des performances Comment utiliser l'extension php XDebug pour un débogage puissant et une analyse des performances Jul 28, 2023 pm 07:45 PM

Comment utiliser l'extension PHP Xdebug pour un débogage et une analyse des performances puissants Introduction : Dans le processus de développement d'applications PHP, le débogage et l'analyse des performances sont des liens essentiels. Xdebug est un puissant outil de débogage couramment utilisé par les développeurs PHP. Il fournit une série de fonctions avancées, telles que le débogage des points d'arrêt, le suivi des variables, l'analyse des performances, etc. Cet article explique comment utiliser Xdebug pour un débogage et une analyse des performances puissants, ainsi que quelques conseils et précautions pratiques. 1. Installez Xdebug et commencez à utiliser Xdebu

Comment effectuer une analyse des performances du code C++ ? Comment effectuer une analyse des performances du code C++ ? Nov 02, 2023 pm 02:36 PM

Comment effectuer une analyse des performances du code C++ ? Les performances sont une considération importante lors du développement de programmes C++. L'optimisation des performances de votre code peut améliorer la vitesse et l'efficacité de votre programme. Cependant, pour optimiser votre code, vous devez d’abord comprendre où se trouvent ses goulots d’étranglement en termes de performances. Pour trouver le goulot d'étranglement des performances, vous devez d'abord effectuer une analyse des performances du code. Cet article présentera certains outils et techniques d'analyse des performances du code C++ couramment utilisés pour aider les développeurs à détecter les goulots d'étranglement des performances dans le code à des fins d'optimisation. Outil de profilage utilisant l'outil de profilage

Outils et techniques pour l'optimisation du code et l'analyse des performances en JavaScript Outils et techniques pour l'optimisation du code et l'analyse des performances en JavaScript Jun 16, 2023 pm 12:34 PM

Avec le développement rapide de la technologie Internet, JavaScript, en tant que langage frontal largement utilisé, reçoit de plus en plus d'attention. Cependant, lors du traitement de grandes quantités de données ou d'une logique complexe, les performances de JavaScript seront affectées. Afin de résoudre ce problème, nous devons maîtriser certains outils et techniques d’optimisation du code et d’analyse des performances. Cet article vous présentera certains outils et techniques d’optimisation du code JavaScript et d’analyse des performances couramment utilisés. 1. Optimisation du code pour éviter les variables globales : les variables globales occuperont plus

Comment utiliser les outils d'analyse des performances pour analyser et optimiser les fonctions Java ? Comment utiliser les outils d'analyse des performances pour analyser et optimiser les fonctions Java ? Apr 29, 2024 pm 03:15 PM

Les outils d'analyse des performances Java peuvent être utilisés pour analyser et optimiser les performances des fonctions Java. Choisissez des outils d'analyse de performances : JVisualVM, VisualVM, JavaFlightRecorder (JFR), etc. Configurez les outils d'analyse des performances : définissez le taux d'échantillonnage, activez les événements. Exécuter la fonction et collecter des données : exécutez la fonction après avoir activé l'outil de profilage. Analysez les données de performances : identifiez les indicateurs de goulot d'étranglement tels que l'utilisation du processeur, l'utilisation de la mémoire, le temps d'exécution, les points chauds, etc. Optimiser les fonctions : utilisez des algorithmes d'optimisation, refactorisez le code, utilisez la mise en cache et d'autres technologies pour améliorer l'efficacité.

Stratégies d'analyse et d'optimisation des performances des files d'attente Java Queue Stratégies d'analyse et d'optimisation des performances des files d'attente Java Queue Jan 09, 2024 pm 05:02 PM

Analyse des performances et stratégie d'optimisation de JavaQueue Résumé de la file d'attente : La file d'attente (file d'attente) est l'une des structures de données couramment utilisées en Java et est largement utilisée dans divers scénarios. Cet article abordera les problèmes de performances des files d'attente JavaQueue sous deux aspects : l'analyse des performances et les stratégies d'optimisation, et donnera des exemples de code spécifiques. Introduction La file d'attente est une structure de données premier entré, premier sorti (FIFO) qui peut être utilisée pour implémenter le mode producteur-consommateur, la file d'attente des tâches du pool de threads et d'autres scénarios. Java fournit une variété d'implémentations de files d'attente, telles que Arr

Conseils de développement C++ : Comment effectuer une analyse des performances du code C++ Conseils de développement C++ : Comment effectuer une analyse des performances du code C++ Nov 22, 2023 pm 08:25 PM

En tant que développeur C++, l'optimisation des performances est l'une de nos tâches incontournables. Afin d'améliorer l'efficacité d'exécution et la vitesse de réponse du code, nous devons comprendre les méthodes d'analyse des performances du code C++ afin de mieux déboguer et optimiser le code. Dans cet article, nous vous présenterons certains outils et techniques d’analyse des performances du code C++ couramment utilisés. Options de compilation Le compilateur C++ fournit des options de compilation qui peuvent être utilisées pour optimiser l'efficacité d'exécution du code. Parmi elles, l’option la plus couramment utilisée est -O, qui indique au compilateur d’optimiser le code. Normalement, nous définirions

See all articles