MySQL的多行插入_MySQL

php中文网
发布: 2016-06-01 13:16:00
原创
1112人浏览过

mysql的多行插入

由于mysql的autocommit默认为打开的,而且很多生产环境都是设置为在事务提交时需要写磁盘,所以提交产生的io开销非常大。在繁忙的oltp系统中,可能这是主要的性能瓶劲.因此减少提交的次数非常重要,尽可能采用批量提交的方式而不是使用单次提交的。

mysql的insert语句本可以支持一次多行insert.这种方式在其他的数据库中没有

比如Oracle.

测试开始前

mysql> show status like '%commit%' ;
 +----------------+-------+
 | Variable_name  | Value |
 +----------------+-------+
 | Com_commit    | 0    |
| Com_xa_commit  | 0    |
| Handler_commit | 0    |
+----------------+-------+
 3 rows in set (0.00 sec)

使用多行insert。
 mysql>  insert into t1(a)       
    ->            values (1),   
    ->                  (2);
 Query OK, 2 rows affected (0.00 sec)
 Records: 2  Duplicates: 0  Warnings: 0

数据库只有提交一次.
 mysql> show status like '%commit%' ;
 +----------------+-------+
 | Variable_name  | Value |
 +----------------+-------+
 | Com_commit    | 0    |
| Com_xa_commit  | 0    |
| Handler_commit | 1    |
+----------------+-------+
 3 rows in set (0.00 sec)

可以看到通过这种方式可以对批量insert进行优化.

SQL>  insert into t1(a)
  2            values (1),
  3                    (2);
 
 insert into t1(a)
            values (1),
                  (2)
 
ORA-00933: SQL command not properly ended

对于这种直接insert多行的方式,oracle数据库不支持。

 

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号