zoukankan      html  css  js  c++  java
  • mysql批量插入,存在则修改,不存在则插入

    批量插入,存在则修改,不存在则插入

    INSERT INTO 表名 (字段1, 字段2, 字段3, 字段4) VALUES (字段1值, 字段2值, 字段3值, 字段4值) ON DUPLICATE KEY UPDATE 存在时需要修改的字段 = 字段值;

    如果在INSERT语句末尾指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则执行旧行UPDATE;如果不会导致唯一值列重复的问题,则插入新行。
    注意:
    ON DUPLICATE KEY UPDATE只是MySQL的特有语法,并不是SQL标准语法!

    INSERT INTO ... ON DUPLICATE KEY UPDATE ...,只UPDATE重复记录,不会改变其它字段

    例如:
    DROP TABLE IF EXISTS `User`;
    CREATE TABLE `User` (
    `id` int(11) NOT NULL,
    `name` varchar(255) DEFAULT NULL,
    `email` varchar(255) DEFAULT NULL,
    PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

    INSERT INTO User (id, name, email) VALUES
    (1, 'nick', 'nick@126.com'),
    (4, 'angel','angel@163.com'),
    (7, 'brank','ba198@126.com');


    方法一:
    INSERT INTO t_member (id, name, email) VALUES
    (1, 'nick', 'nick@126.com'),
    (4, 'angel','angel@163.com'),
    (7, 'brank','ba198@126.com')
    ON DUPLICATE KEY UPDATE name = VALUES(name), email = VALUES(email);
    如果存在则将name和email用对应name和email值替换

    方法二:
    INSERT INTO t_member (id, name, email) VALUES
    (1, 'nick', 'nick@126.com'),
    (4, 'angel','angel@163.com'),
    (7, 'brank','ba198@126.com')
    ON DUPLICATE KEY UPDATE name = 'name1', email = '1232@qq.com';
    如果存在则将name用name1替换,email用1232@qq.com值替换

  • 相关阅读:
    Slim + Twig 构建PHP Web应用程序
    Slim
    nginx+php+flight 构建RESTFul API
    Redis Master/Slave 实践
    spring.net +dapper 打造简易的DataAccess 工具类.
    API文档管理工具-数据库表结构思考.
    解决oracle报 ORA-12560错误,只有服务器重启恢复正常的问题
    浮点数的编码
    Jquery.BlockUI-遮罩
    class.forname & classloader
  • 原文地址:https://www.cnblogs.com/WebLinuxStudy/p/13826290.html
Copyright © 2011-2022 走看看