当前位置: 首页 > news >正文

企业网站建设排名西安百度推广排名

企业网站建设排名,西安百度推广排名,泉山微网站开发,工业电商做网站怎么样方式1 ON DUPLICATE KEY UPDATE 使用前提:表必须配置唯一键或者主键,且保存的字段中包含该键【重点】 原理: ON DUPLICATE KEY UPDATE如果配合主键,存在数据a,新插入b,如果主键不冲突,会保存b…

方式1 ON DUPLICATE KEY UPDATE

使用前提:表必须配置唯一键或者主键,且保存的字段中包含该键【重点】
原理:

  1. ON DUPLICATE KEY UPDATE如果配合主键,存在数据a,新插入b,如果主键不冲突,会保存b。如果b主键和a冲突会删除b,然后更新a。
  2. ON DUPLICATE KEY UPDATE如果配合唯一键,mysql先插入一条数据,然后根据唯一键判断唯一键是否冲突,如果已经存在该键,就会删除后面插入的数据,对前面的那条数据执行更新操作。比如已经存在A,此时插入一条B,B和A冲突就会删除B,对A执行后面的更新操作。所以造成主键id+1。

基本语法

插入的字段必须包含master_id, award_name,这两个字段,否则唯一索引无效,mysql无法发现索引冲突,会一直执行保存动作,不会执行更新。
单条插入或者更新

INSERT INTO reward_center_award  (master_id, award_name) VALUES('432564','京东e卡')
ON DUPLICATE KEY UPDATE 
award_name='杜卡迪一辆'

批量插入或者更新

INSERT INTO reward_center_award  (master_id, award_name,award_type) VALUES('432564','京东e卡',4), ('432564','杜卡迪',1),('432564','春风450',2)ON DUPLICATE KEY UPDATE 
award_name='杜卡迪一辆'

初始化表

主键id,唯一索引由master_id,award_name组成,意思同一个品牌商的奖品名称是唯一的。

DROP TABLE IF EXISTS reward_center_award;
CREATE TABLE `reward_center_award` (`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键id',`state` tinyint(4) NOT NULL DEFAULT '1' COMMENT '是否删除(0:删除,1可用)',`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',`reward_guid` varchar(50) DEFAULT NULL COMMENT '奖励标识guid',`master_id` varchar(50) DEFAULT NULL COMMENT '品牌主Id',`master_name` varchar(50) DEFAULT NULL COMMENT '品牌主名称',`award_name` varchar(50) DEFAULT NULL COMMENT '奖品名称',`award_type` tinyint(4) DEFAULT NULL COMMENT '奖励类型 1:店铺商品,2:线下商品,3:积分,4:优惠券',`goods_name` varchar(100) DEFAULT NULL COMMENT '商品名称',`goods_price` decimal(13,2) DEFAULT NULL COMMENT '商品价格',`number` bigint(11) DEFAULT '0' COMMENT '奖品总数',PRIMARY KEY (`id`),UNIQUE KEY `master_id_award_name` (`master_id`,`award_name`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='奖品中心奖品表';

1. 表一开始为空,所以这里是保存一条数据。

INSERT INTO reward_center_award  (master_id, award_name) VALUES('432564','京东e卡')
ON DUPLICATE KEY UPDATE 
award_name='杜卡迪一辆'

在这里插入图片描述
执行结果
在这里插入图片描述
2. 同样的语句再执行一次
因为前面插入了一条数据a,这次又插入一条一样的数据b,这次会唯一索引冲突,会删除b,然后对a执行更新操作,主键id+1

INSERT INTO reward_center_award  (master_id, award_name) VALUES('432564','京东e卡')
ON DUPLICATE KEY UPDATE 
award_name='杜卡迪一辆'

在这里插入图片描述
在这里插入图片描述
3. 再插入一条不同的数据
因为前面主键+1,所以这里id从3开始了

INSERT INTO reward_center_award  (master_id, award_name) VALUES('432564','春风450')
ON DUPLICATE KEY UPDATE 
award_name='杜卡迪一辆'

在这里插入图片描述

方式二:REPLACE INTO

也需要存在主键或者唯一键
先删除原来数据,再插入。比如表里有A,插入一条和A一样的B时,会把A删除再插入B。

基本语法

插入的字段必须包含master_id, award_name,这两个字段,否则唯一索引无效,mysql无法发现索引冲突,会一直执行保存动作,不会执行更新。
单条插入或者更新

REPLACE INTO 表名(字段1,字段2)
VALUES(值A,值B);

批量插入或者更新

REPLACE INTO 表名(字段1,字段2)
VALUES(值A,值B),(值A,值B),(值A,值B),(值A,值B);

和上面同样的表

DROP TABLE IF EXISTS reward_center_award;
CREATE TABLE `reward_center_award` (`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键id',`state` tinyint(4) NOT NULL DEFAULT '1' COMMENT '是否删除(0:删除,1可用)',`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',`reward_guid` varchar(50) DEFAULT NULL COMMENT '奖励标识guid',`master_id` varchar(50) DEFAULT NULL COMMENT '品牌主Id',`master_name` varchar(50) DEFAULT NULL COMMENT '品牌主名称',`award_name` varchar(50) DEFAULT NULL COMMENT '奖品名称',`award_type` tinyint(4) DEFAULT NULL COMMENT '奖励类型 1:店铺商品,2:线下商品,3:积分,4:优惠券',`goods_name` varchar(100) DEFAULT NULL COMMENT '商品名称',`goods_price` decimal(13,2) DEFAULT NULL COMMENT '商品价格',`number` bigint(11) DEFAULT '0' COMMENT '奖品总数',PRIMARY KEY (`id`),UNIQUE KEY `master_id_award_name` (`master_id`,`award_name`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='奖品中心奖品表';

插入两条数据

INSERT INTO reward_center_award  (master_id, award_name,award_type) VALUES('432564','杜卡迪','1'),('432564','春风450','2');

在这里插入图片描述

REPLACE INTO reward_center_award  (master_id, award_name,award_type) VALUES('432564','杜卡迪',3);

id=1的被删除了,插入了一条新数据
在这里插入图片描述
完结!!!
在这里插入图片描述

http://www.hengruixuexiao.com/news/5249.html

相关文章:

  • 麻涌企业网站建设百度seo排名软
  • 网站免费推广怎么做百度竞价排名软件
  • 网站收录 作用友情链接购买平台
  • 海口 网站开发做运营的具体做什么
  • 网站小logo设计黄页88推广多少钱一年
  • 陕西政务服务网注册公司流程搜索引擎优化核心
  • 深圳手机建网站做竞价推广大概多少钱
  • 郑州网站优化岳阳seo公司
  • 专业模板网站制作哪家好个人免费网站创建入口
  • 武汉做网站网络公司广州百度提升优化
  • 平面设计网站免费大推荐广州推广seo
  • 网站设置为应用程序网站设计的流程
  • 接收新网站如何做诊断免费建站网站
  • 网站建设佰首选金手指十八竞价广告是什么意思
  • 网站开发维护报价单今日国家新闻
  • 个人做搜索网站违法吗南京高端品牌网站建设
  • wordpress 100并发网站站外优化推广方式
  • 济南简单的网站制作十大互联网平台
  • 做网站如何自动采集图片上海seo外包公司
  • 胶州网站建设哪里有优化算法
  • 毕业做网站运营好吗上海aso
  • dede大气黑色网站源码百度关键词优化词精灵
  • 网站建设的英文翻译凡科建站官网登录
  • 视频网站亏损也做手机清理优化软件排名
  • 高埗做网站公司网络推广项目计划书
  • 曙光建设有限公司网站百度推广怎么推
  • 邢台医院网站建设seo常见的优化技术
  • 洛阳公司青峰做的企业网站地推项目平台
  • 网站建设600元包百家号seo怎么做
  • 视频多平台发布黄山网站seo