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;
单表更新操作
UPDATE product
SET price='20.00',type=0
WHERE proID=2;
关联更新操作
UPDATE producttype,product
SET producttype.amount=product.price
where product.TYPE = producttype.ID AND product.TYPE=1;
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);
注意:大家注意看到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,如果之前有事情其它数据库产品的习惯在这里要注意了。

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Canvas 프레임워크 탐색: 일반적으로 사용되는 Canvas 프레임워크가 무엇인지 이해하려면 특정 코드 예제가 필요합니다. 소개: Canvas는 풍부한 그래픽 및 애니메이션 효과를 얻을 수 있는 HTML5에서 제공되는 그리기 API입니다. 그리기의 효율성과 편의성을 향상시키기 위해 많은 개발자들이 다양한 Canvas 프레임워크를 개발했습니다. 이 기사에서는 일반적으로 사용되는 몇 가지 캔버스 프레임워크를 소개하고 독자가 이러한 프레임워크를 사용하는 방법을 더 깊이 이해하는 데 도움이 되는 특정 코드 예제를 제공합니다. 1. EaselJS 프레임워크 Ea

Spring은 Java 개발을 단순화하고 향상시키기 위해 많은 주석을 제공하는 오픈 소스 프레임워크입니다. 이 기사에서는 일반적으로 사용되는 Spring 주석을 자세히 설명하고 구체적인 코드 예제를 제공합니다. @Autowired: Autowired @Autowired 주석은 Spring 컨테이너에 Bean을 자동으로 연결하는 데 사용할 수 있습니다. 종속성이 필요한 @Autowired 주석을 사용하면 Spring은 컨테이너에서 일치하는 Bean을 찾아 자동으로 주입합니다. 샘플 코드는 다음과 같습니다. @Auto

상위 15 개의 Bitcoin Escape Index에 대한 심층 분석 : 2025 년 시장 전망이 기사는 일반적으로 사용되는 15 개의 Bitcoin Escape Index를 깊이 분석하며, 그 중 비트 코인 Rhodl 비율, USDT 현재 자산 관리 및 Altcoin 계절 지수가 2024 년에 탈출 지수에 도달하여 시장의 관심을 끌었습니다. 투자자는 어떻게 잠재적 위험을 처리해야합니까? 이러한 지표를 하나씩 해석하고 합리적인 대응 전략을 탐색합시다. 1. 주요 지표에 대한 자세한 설명 AHR999 Coin Hoarding Indicator : AHR999에 의해 생성, 비트 코인 고정 투자 전략 지원. 현재 값은 1.21로 대기중인 범위에 있으므로 조심해야합니다. AHR999에 대한 링크 Escape Top Indicator : AHR999 Coin Hoarding Indicator 보충제, 시장의 최고를 식별하는 데 사용됩니다. 현재 값은 이번 주 2.48입니다

인터넷의 발달로 인해 데이터 보안은 일상 업무에서 주의를 기울여야 하는 심각한 문제가 되었습니다. 민감한 개인 정보나 비즈니스 데이터의 경우 암호화가 특히 중요합니다. PHP 개발에서는 일부 암호화 알고리즘이 널리 사용됩니다. PHP에서 일반적으로 사용되는 암호화 알고리즘을 살펴보겠습니다. 1. Base64 인코딩 Base64 인코딩은 웹 페이지나 이메일에서 바이너리 데이터를 전송할 때 자주 사용됩니다. 웹 페이지나 이메일은 문자열 형식의 데이터만 전송할 수 있고 바이너리 데이터를 직접 전송할 수 없기 때문입니다. Base64는 솔루션입니다

Oracle 데이터베이스는 다양한 요구 사항을 충족하기 위해 여러 데이터 유형을 지원하는 일반적으로 사용되는 관계형 데이터베이스 관리 시스템입니다. Oracle 데이터베이스를 사용할 때에는 데이터베이스의 데이터 유형을 이해하는 것이 매우 중요합니다. 이 문서에서는 특정 코드 예제와 함께 Oracle 데이터베이스에서 일반적으로 사용되는 데이터 유형을 소개합니다. 1. 숫자 데이터 유형 NUMBERNUMBER는 Oracle 데이터베이스에서 가장 일반적으로 사용되는 숫자 데이터 유형으로 정수 또는 부동 소수점 숫자를 저장하는 데 사용됩니다. NUMBER 데이터 유형은 정밀도를 지정할 수 있습니다.

Go 언어에서 일반적으로 사용되는 기능은 무엇입니까? ——Go 언어에서 일반적으로 사용되는 기능과 사용법을 살펴보세요. 널리 사용되는 정적인 유형의 프로그래밍 언어인 Go 언어는 서버 측 개발, 네트워크 프로그래밍, 클라우드 컴퓨팅 등과 같은 다양한 분야에서 널리 사용됩니다. Go 언어에서 함수는 기본 코드 구성 단위로서 프로그램 실행의 중요한 부분입니다. 이 기사에서는 독자가 Go 언어의 핵심 기능을 더 잘 이해할 수 있도록 Go 언어에서 일반적으로 사용되는 기능과 사용법을 살펴보겠습니다. 1. "fun"이라는 키워드를 사용하여 Go 언어에서 함수 선언 및 함수 호출

소프트웨어 개발 분야는 오랜 기간에 걸쳐 극적으로 변화했으며 DevOps는 현대 컴퓨터 프로그램 제공 프로세스의 필수적인 부분이 되었습니다. 컴퓨터 프로그램 개발 및 운영 프로세스를 간소화하기 위해 DevOps는 협업, 지속적인 통합 및 논스톱 제공 문화를 조성합니다. 프로그래밍 언어의 선택은 DevOps의 효율적인 활용에 중요한 역할을 하며, 이 분야에서 잘 알려진 두 경쟁자는 Ruby와 Python입니다. 여기에서는 DevOps 환경에서 Ruby와 Python의 선택, 인기, 사용 사례를 살펴보겠습니다. DevOps 요구 사항에 가장 적합한 언어를 결정하는 데 도움이 되도록 고유한 기능, 장점 및 단점을 조사하겠습니다. 섹션 1: Ruby와 Python

Java는 널리 사용되는 프로그래밍 언어이며 데이터 구조는 개발 프로세스의 필수적인 부분입니다. 데이터 구조는 데이터를 구성 및 관리하고 프로그램 실행 효율성을 향상시키는 데 도움이 됩니다. Java에서 일반적으로 사용되는 데이터 구조에는 배열, 연결 목록, 스택, 큐, 트리, 그래프 등이 포함됩니다. 이 기사에서는 일반적으로 사용되는 Java 데이터 구조에 대한 심층 분석을 제공하고 특정 코드 예제를 제공합니다. 1. 배열 배열은 동일한 유형의 요소를 저장할 수 있는 선형 데이터 구조입니다. Java에서는 다음을 사용하여 선언할 수 있습니다.
