• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > MySQL 查询 批量插入 批量更新 优化的详情介绍

MySQL 查询 批量插入 批量更新 优化的详情介绍

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了MySQL ,批量插入,批量更新等相关知识,希望本文的分享对您有所帮助
最近在研究mysql的时候,遇到了mysql批量插入、批量更新效率不高的问题,之前一直在用sqlserver,mysql本身效率还是不错的,这里把提升效率方法记录下,就不对比时间了,实际测试结果效率提升很多。

创建表结构

1 DROP TABLE IF EXISTS `b_student`;
2 CREATE TABLE `b_student` (
3   `id` int(11) NOT NULL AUTO_INCREMENT,
4   `examcode` varchar(20) CHARACTER SET gbk NOT NULL DEFAULT '',
5   `stucode` varchar(20) CHARACTER SET gbk NOT NULL DEFAULT '',
6   `name` varchar(20) CHARACTER SET gbk NOT NULL DEFAULT '',
7   PRIMARY KEY (`id`)
8 ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

查询优化,场景是判断examcode是否存在

SELECT 1 FROM b_student WHERE examcode='10001'  limit 1;

查询结果1表示存在,结果null表示不存在

批量插入优化,场景批量插入学生信息

INSERT INTO `b_student` (`examcode`,`stucode`,`name`) VALUES('10001','10001','张三'),('10002','10002','李四');

批量更新优化,场景批量更新学生信息

批量插入这里介绍两种方法(要求表有主键),还有其他的方式。

1、replace into方法,根据主键更新某列或某几列,注意:这种方式会把除id和name之外的列清空。

replace into b_student (id,name) values (1,'张三丰'),(2,'李思思');

2、insert into ...on duplicate key update 方法,根据主键更新update后定义的列

insert into b_student (id,stucode) values (1,'20001'),(2,'20002') on duplicate key update stucode=values(stucode);

以上两种方法在批量更新时效率非常高,根据实际情况进行选择。

以上就是MySQL 查询 批量插入 批量更新 优化的详情介绍的内容,更多相关内容请关注微课江湖()!

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • MySQL essential版本和普通版本有什么区别?
  • 如何用SQL命令查看Mysql数据库大小
  • 解析mysql中如何获得数据库的大小
  • 解析mysql修改为utf8后仍然有乱码的问题
  • 解析远程连接管理其他机器上的MYSQL数据库
  • MySQL timestamp自动更新时间分享
  • MySQL Order by 语句用法与优化详解
  • 深入解析mysql中order by与group by的顺序问题
  • 解析mysql不重复字段值求和
  • MySql实现跨表查询的方法详解

相关文章

  • 2018-12-05mysql-5.7.12解压版安装步骤教程
  • 2018-12-05关于服务器连接的10篇文章推荐
  • 2018-12-05MySQL授权命令grant的使用方法详解
  • 2018-12-05MySQL 在触发器里中断记录的插入或更新?
  • 2018-12-05主流的NoSQL数据库--MongoDB权限设置的详解
  • 2018-12-05用正则表达式替换数据库中的内容的实例详解
  • 2018-12-05mysql中将null值转换为0的语句
  • 2018-12-05MySql5.7.18字符集配置图文实例分享
  • 2018-12-05Mysql row number()排序函数的用法和注意_MySQL
  • 2017-05-11mysql 服务意外停止1067错误解决办法小结

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • SQL server 管理事务和数据库介绍
    • 禁止mysql做域名解析(解决远程访问mysql时很慢)
    • 关于修复损坏的详细介绍
    • 数据库导出与导入的实例总结
    • Mysql的增删改查sql语句总结
    • 求教连接mysql数据库的一个问题
    • MSSQL 添加字段说明
    • 解决hibernate+mysql写入数据库乱码
    • MongoDB插入查询数据(二), 条件查询
    • 绿色版 mysql 安装配置

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有