찾다
데이터 베이스MySQL 튜토리얼MySQL 常用的UPDATE操作_MySQL

概述  

 

测试环境:mysql 5.6.21

 

 

 

步骤

 

创建测试表

 

 

CREATE TABLE `product` (

   `proID` int(11) NOT NULL AUTO_INCREMENT COMMENT '商品表主键',

   `price` decimal(10,2) NOT NULL COMMENT '商品价格',

   `type` int(11) NOT NULL COMMENT '商品类别(0生鲜,1食品,2生活)',

   `dtime` datetime NOT NULL COMMENT '创建时间',

   PRIMARY KEY (`proID`)

 ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='商品表';

 

CREATE TABLE `producttype` (

   `ID` int(11) NOT NULL COMMENT '商品类别(0生鲜,1食品,2生活)',

   `amount` int(11)  COMMENT '每种类别商品总金额',

   UNIQUE KEY (`ID`)

 ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商品类别资金汇总表'

 

插入测试数据

 

INSERT INTO product(price,type,dtime) VALUES(10.00,0,now()),(10.00,1,now()),(10.00,1,now()),(20.00,2,now()),(30.00,3,now());

 

INSERT INTO producttype(ID) VALUES(1),(2),(3);

SELECT * FROM  product;

 

SELECT * FROM producttype;

MySQL 常用的UPDATE操作_MySQL

 

 单表更新操作

 

UPDATE product

SET price='20.00',type=0 

WHERE proID=2;

MySQL 常用的UPDATE操作_MySQL

 

 关联更新操作 

 

UPDATE producttype,product

SET producttype.amount=product.price

where product.TYPE = producttype.ID AND product.TYPE=1;

MySQL 常用的UPDATE操作_MySQL

 

 1.查询所有字段

 

INSERT INTO producttype(ID) VALUES(4);

UPDATE producttype

SET producttype.amount= (SELECT ifnull(SUM(product.price),0.00)    FROM product WHERE product.TYPE = producttype.ID GROUP BY product.TYPE);

 

MySQL 常用的UPDATE操作_MySQL

注意:大家注意看到rows matched:4,表示符合条件的记录是4条,实际更新了三条,关联语句默认不去判断里面的关联的实际行。

 

2.只查询需要更新的字段

 

UPDATE producttype

SET amount=null;

 

UPDATE producttype,product

    SET producttype.amount= 

       (SELECT ifnull(SUM(product.price),0.00)

          FROM product

             WHERE product.TYPE = producttype.ID

             GROUP BY product.TYPE)

 where product.TYPE = producttype.ID;

 

 

 

改用下面这种方法:Rows matched:3,查询到了符合条件的行是3行,没有查询无关联的行。

 

总结

 

 mysql的update的关联操作在5.6中后面不能直接接FROM语句,只能UPDATE 所有的连接表然后WHERE,如果之前有事情其它数据库产品的习惯在这里要注意了。

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
学习canvas框架 详解常用的canvas框架学习canvas框架 详解常用的canvas框架Jan 17, 2024 am 11:03 AM

探索Canvas框架:了解常用的Canvas框架有哪些,需要具体代码示例引言:Canvas是HTML5中提供的一个绘图API,通过它我们可以实现丰富的图形和动画效果。为了提高绘图的效率和便捷性,许多开发者开发了不同的Canvas框架。本文将介绍一些常用的Canvas框架,并提供具体代码示例,以帮助读者更深入地了解这些框架的使用方法。一、EaselJS框架Ea

Spring注解大揭秘:常用注解解析Spring注解大揭秘:常用注解解析Dec 30, 2023 am 11:28 AM

Spring是一个开源框架,提供了许多注解来简化和增强Java开发。本文将详细解释常用的Spring注解,并提供具体的代码示例。@Autowired:自动装配@Autowired注解可以用于自动装配Spring容器中的Bean。当我们在需要依赖的地方使用@Autowired注解时,Spring将会在容器中查找匹配的Bean并自动注入。示例代码如下:@Auto

15个常用的币圈逃顶指标技术分析15个常用的币圈逃顶指标技术分析Mar 03, 2025 pm 05:48 PM

十五大比特币逃顶指标深度解析:2025年市场展望本文深入分析了十五个常用的比特币逃顶指标,其中比特币Rhodl比率、USDT活期理财和山寨币季节指数已于2024年触及逃顶区间,引发市场关注。面对潜在风险,投资者该如何应对?让我们逐一解读这些指标,并探讨合理的应对策略。一、关键指标详解AHR999囤币指标:由ahr999创建,辅助比特币定投策略。当前值为1.21,处于观望区间,建议谨慎。链接AHR999逃顶指标:AHR999囤币指标的补充,用于识别市场顶部。当前值为2.48,本周

PHP中常用的加密算法有哪些?PHP中常用的加密算法有哪些?May 12, 2023 pm 06:51 PM

随着互联网的发展,数据安全已成为我们日常工作中必须关注的严肃问题。针对敏感的个人信息或商业数据,加密变得尤为重要。在PHP开发中,一些加密算法被广泛应用,下面我们就来了解一下PHP中常用的加密算法。一、Base64编码Base64编码常用于在网页传输或邮件中传输二进制数据,因为网页或邮件只能传发送字符串类型数据,不能直接传输二进制数据。Base64就是一种解

Oracle数据库常用数据类型介绍Oracle数据库常用数据类型介绍Mar 08, 2024 am 09:45 AM

Oracle数据库是一种常用的关系型数据库管理系统,它支持多种数据类型以满足不同的需求。在使用Oracle数据库时,了解数据库的数据类型是非常重要的。本文将介绍Oracle数据库中常用的数据类型,并附带具体的代码示例。一、数值型数据类型NUMBERNUMBER是Oracle数据库中最常用的数值型数据类型,用于存储整数或浮点数。NUMBER数据类型可以指定精度

Go语言中常用的函数有哪些?Go语言中常用的函数有哪些?Mar 28, 2024 pm 02:45 PM

Go语言中常用的函数有哪些?————探究Go语言中常用的函数及其用法作为一门流行的静态类型编程语言,Go语言广泛应用于各种领域,如服务器端开发、网络编程、云计算等。在Go语言中,函数作为基本的代码组织单元,是程序运行的重要组成部分。本文将探究Go语言中常用的函数及其用法,帮助读者更好地掌握这门语言的核心特性。一、函数声明与调用函数在Go语言中以关键字"fun

Java常用的数据结构有哪些?深入解析Java数据结构Java常用的数据结构有哪些?深入解析Java数据结构Jan 09, 2024 pm 11:29 PM

Java是一种广泛使用的编程语言,在开发过程中,数据结构是不可或缺的一部分。数据结构有助于组织和管理数据,提高程序的执行效率。在Java中,常用的数据结构包括数组、链表、栈、队列、树、图等。本文将深入解析这些常用的Java数据结构,并提供具体的代码示例。一、数组(Array)数组是一种线性数据结构,它可以存储相同类型的元素。在Java中,可以使用以下方式声明

哪个在DevOps中更常用:Ruby还是Python?哪个在DevOps中更常用:Ruby还是Python?Aug 19, 2023 am 11:41 AM

软件开发领域在很长时间内发生了巨大变化,DevOps已成为现代计算机程序交付过程中的基本组成部分。为了简化计算机程序开发和运营的过程,DevOps培养了一种合作、持续集成和不间断交付的文化。编程语言的选择在DevOps的高效利用中起着重要作用,而在这个领域中两个知名的竞争者是Ruby和Python。在这里,我们将研究Ruby和Python在DevOps环境中的选择、流行度和使用案例。我们将调查它们独特的特点、优点和缺点,以帮助您决定哪种语言最适合您的DevOps需求。第一节:Ruby和Pytho

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기