京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 9613|回复: 0

MySQL基础教程之DML语句详解

[复制链接]

19

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2022-1-10 20:30:50 | 显示全部楼层 |阅读模式 来自 中国
目录
. `1 D$ ^* v0 `/ b
# P% M. B$ n2 ^) n* x" l

    + A. E: j! M, F$ C# d
  • DML 语句5 F9 b' g$ ?! o9 V( A
  • 1.插入记录
    & X0 F: b1 V. c9 X' H- F$ l
  • 2.更新记录
    1 z% Q% e- ^9 `, z6 o( r
  • 3.简单查询记录) j1 e% {1 ~# |/ q5 G( i
  • 4.删除记录
    ( M* e+ T2 c1 h" Y% Y: y
  • 5.查询记录详解(DQL语句)
    & R; }, \7 F' C# \3 O

      9 z2 T* Y/ F2 o7 W* q$ K
    • 5.1.查询不重复的记录/ K; D' p, B6 c6 ^" \
    • 5.2.条件查询
      4 B+ T* R, F- f
    • 5.3.聚合查询
      7 |8 q) A7 @  f
    • 5.4.排序查询
      0 \7 D* v: w% C6 y4 v
    • 5.5.limit查询
      + j! Z1 V4 S1 ?. P& O0 B
    • 5.6.连表查询; F, m! q. ?- S& l0 [( x
    • 5.7.子查询
      5 z8 v. J  \0 v( x
    • 5.8.记录联合
      0 x0 r  e; h# S1 M( s
    • 5.9.select语句的执行顺序7 ~8 K' K$ {9 R
    $ ^4 }3 i! y9 n) S( T/ {8 T* V
  • 6.总结0 y' g& \! v* I1 u- D+ f
, L2 S: P3 T/ E& ~7 a" v7 X  e# K+ V
DML 语句1 M, h; N" L4 s% ~$ r4 f' P, d) g

" s$ Y  ~7 |+ {5 R4 G  }DML(Data Manipulation Language)语句:数据操纵语句。' i  h" }' ]: ]- f
用途:用于添加、修改、删除和查询数据库记录,并检查数据完整性。
: V. d# C2 }4 ?+ P! Z& h/ `常用关键字:insert、update、delete、select等。* a1 w3 w% L4 i. n$ [) }: `. g% K
DML 操作的对象是库表的数据(记录)。2 f! I9 S/ ]5 a2 N
主要包括插入(insert)、更新(update)、删除(delete)和查询(select)。" a  T" ^% C) G5 p) s
DML 语句是开发人员使用最频繁的操作。
7 j  f2 X* _# {" P- c) a/ x& p
/ }! H( D7 L6 a( o6 ~1.插入记录
1 f) e: H+ C1 Y/ \# E! z  \( |2 G! j, \" t8 J0 w5 Y. z0 `' r
插入一条记录
  1. insert into tablename (field1,field2,...,fieldn) values (value1,value2,...,valuen);
复制代码
一次性插入多条数据
  1. insert into tablename (field1,field2,...,fieldn)values (value1,value2,...,valuen), (value1,value2,...,valuen);
复制代码
2.更新记录
' W8 U3 L( X' a  j- W/ ~& P
# h( s7 b1 f  {  s3 I! E更新单表数据
  1. update tablename set field1=value1,filed2=value2,...fieldn=valuen [where condition]
复制代码
同时更新多个表的数据
  1. update t1,t2,...,tn set t1.field1=expr1,tn.field=exprn [where condition];
复制代码
通常用于根据一个表的字段来动态地更新另外一个表的字段
" Q* w- J+ e$ Q  p& N# @在此说明:中括号 “[ ]” 代表的是可选参数,即可有可无的参数。
" m( e1 q+ K/ |1 \
" q* t% n; G, y( _3.简单查询记录% @# t3 b" J! i" n( D: z
- k$ M  E* y& P# f4 s% `
简单的条件查询。符号“*”代表查询所有字段,如果只想看其中某些列,则写表的列名。
  1. select * from tablename [where condition];select field1,field2,...,fieldn from tablename [where condition];
复制代码
别名& Z2 v$ \" b: d3 {
    给列名或表名取别名的关键字:AS 或者不写关键字。如:
  1. select field1 AS f1,field2 f2  from tablename;select t2.field1 AS f1,t1.field2 f2  from table1 as t1,table2 t2;
复制代码
不取别名,则查询结果的列名为表原本的列名;
. N6 u1 U# ]2 h; j3 e) T. s取别名,则查询结果的列名为别名1 b. {# L/ _, N; ?9 j) J$ W
' j+ a8 z' X3 a& z( ]

7 A9 a7 N3 R* C. G- }4.删除记录1 e8 {! b6 A6 h" l- X+ C- _

( y: \4 V+ E7 ^' m删除单表记录
  1. delete from tablename [where condition];
复制代码
同时删除多个表的数据
  1. delete t1,t2,...,tn from t1,t2,...,tn [where condition];
复制代码
说明:不加where 条件则删除全表数据
. T3 ^" ?: I) {单表“增改查删”操作案例:
% k7 {& \* I' G: ^! Y. W
% @' Z* d) a4 F! ~9 |( x7 C; h
多表“删除”操作案例:
6 x( N. z8 h* t6 U2 S, {# n
: U) W( q1 W% t% [/ ?' C. h, }! Q
  再看个删除案例9 c2 s; V$ M1 X- b3 _# f+ g
, F, Z2 G: a/ s# j0 I) ]
 最后再看个删除案例& R) y! J3 B  w- z9 W' U

1 E% C. j9 F+ O+ _, w多表删除结论:
) V+ u0 @$ N8 T- K  W: P8 d  条件成立,则删除有条件表的对应数据,没条件的则全表删除;
$ H6 s4 k8 v: T9 V  条件不成立,则都不删除。
, d4 A+ o: B' @( v+ @留个疑问:多表删除不给where 条件会怎样呢?5 l3 o3 r) l+ _2 v, I. v. g- \; p
关于同时更新多个表数据的操作,可以自行探索,毕竟有思考的学习最有价值。
# `3 r* b/ \& V, G# p. V
, f* I) I  X! x0 I4 k; T5 u% M5.查询记录详解(DQL语句)" `8 L, ]8 x2 ]5 U  ]$ G

0 W7 d" s3 l2 l) o0 s3 KDQL(Data Query Language)即数据库查询语言。
2 c: _$ @, a2 K) l; H数据库查询语句就像玩积木一样,一块一块的拼凑,每个中括号“[]”代表一块积木。
) ?) r  S4 r1 J& W先通过递进的方式一条一条列出查询语法。
- J8 Z/ e3 Z" l  M
. q9 X8 {8 v2 {; x, u+ E5.1.查询不重复的记录
/ }8 r+ g+ J& D# f8 L) J$ h
  1. select distinct filed from tablename;
复制代码

( ^5 R% v  C3 f3 C, ]distinct 关键字是对 “查询结果集” 去重,再看个例子就明白了。* [3 f3 S. G7 w, E4 ^- t! }5 P: ~
9 W  u5 S; P) `' c6 _: C
* M  j& \, y6 t1 h
5.2.条件查询' u* {/ c6 y! P' S, T$ i+ R
  1. --查询所有列:select * from tablename [where condition];--查询指定列:select [field1,field2,...,fieldn] from tablename [where condition];
复制代码
常用的条件(condition)0 F' W2 |5 V0 I& p# T
等于:field = xxx' A1 p% O7 z+ B
大于:field > xxx. w: F9 M9 u. F% a
小于:field < xxx
* V. ?- m4 T+ g7 T1 G不等于:field != xxx
4 K8 }$ C" o9 |; y8 F- f不等于:field  xxx
0 H& o; C6 l& M! l/ o2 r等于null:field is null& f% ?, Y! I3 ~: o* k9 @; z( \
不等于null:field is not null0 i7 m  p2 u3 k2 [
多个条件之间用逻辑运算符:and 和 or 
$ y2 T8 h( E  `; t模糊查询之"_":field like _x_xx_     符号"_"代表匹配单个任意字符,可以在你喜欢的字符旁加上"_"1 j6 ?  ?* Y8 W+ U' m
模糊查询之"%":field like %x%xx%     符号"%"代表匹配0~n个任意字符,可以在你喜欢的字符旁加上"%"8 D5 y7 U5 g/ O3 r
in语句查询:field in(value1,value2,...)  查询field 和 in 数组配得上的,不配就没有数据
' @  i& B; u+ T  N/ J  ?/ p% X9 f+ s7 |not in语句查询:field not in(value1,value2,...)   查询field 和 in 数组配不上的,不配就有数据+ i& D3 W! o$ |, E+ |5 X' `; ^
其它常用条件具体怎么用,参考常用条件去操作。! F" U( r4 C3 f' {4 c2 K
: Q, X9 T. I6 Q) c: c9 Z$ A9 g
% p0 i8 K& K0 G- M8 f7 v
5.3.聚合查询2 D8 n7 o' n7 P' g
  1. --最简单的聚合查询:select [field1,field2,...,fieldn] fun_name from tablename group by field;--完整语法:select [field1,field2,...,fieldn] fun_name from tablename [where condition] [group by field1,field2,...,fieldn [with rollup]] [having condition];
复制代码
说明:
! v7 {" b" M7 h$ o
fun_name  表示聚合函数,常用有:求和sum()、记录数count(*)、平均值avg()、最大值max()、最小值min();; x* U6 \$ d$ T' B' S; b! f  r. k
[where condition] 就是上面讲的条件查询;
. e' }' l" N4 ~: i[group by field1,field2,...,fieldn [with rollup]] 
3 M* u# ?/ }! l6 ^) u  group by 关键字表示对field字段进行分类聚合;
1 U! _# e/ A  s  with rollup 关键字表示是否对分类聚合后的结果进行再汇总
) t" R  P! R# H: E2 J) ~[having condition] 对分类聚合后的查询结果集进行条件的过滤4 A7 q, S/ i& m" Q8 |
where 和 having 的区别:2 U) Y4 d( F0 y/ U2 g5 B4 q
        9 h( R  x( m6 m
  • where 是分组前的条件过滤;having 是分组后的条件过滤。   
    1 O2 d- p) ?& g7 \* A9 K2 S5 H* |0 M
  • where 是用原表列名做条件过滤;having 是用查询结果集列名做条件过滤。
    " `% N3 g5 l3 ?
    优先选择where 条件过滤,这样可以减少结果集,进而提高分类聚合的效率。5 [- i: V. h/ f. z0 E, m: o2 e
中括号"[]"代表可选的意思,也就是说group by 前面的[where condition] 可有可无,后面的[with rollup] 和 [having condition] 也是可有可无。( j8 G. L  l5 N9 h8 _
group by 和distinct 的区别:    group by 是对指定列进行分组;distinct 是对查询结果进行去重。
0 `' J: I9 _9 z0 B9 P

* b$ e3 ~" G+ L% i3 z: l( d加入where 和 having的例子:
6 F$ ?& O% M6 i' E

& D, B6 X# Y# B9 J. I列名为avg(stu_age) 看着有点怪怪,给他取个别名就一目了然:# d8 l& t1 ?# D  K! D/ {; a
, G3 {, n- L: e5 G8 Y* {+ y3 G
" S( `+ r7 O* E: h( Y; V
5.4.排序查询- T- ?( s% e* H
  1. --最简单的排序查询:select * from tablename order by field;--完整语法:select [field1,field2,...,fieldn] fun_name from tablename [where condition] [group by field1,field2,...,fieldn [with rollup]] [having condition] [order by field1 [desc|asc], field2 [desc|asc],...,fieldn [desc|asc]];DESC 代表降序(从大到小);ASC 代表升序(从小到大),asc为默认排序。也就是说你只要记住desc 就可以了。碰巧的是desc 是查询表设计的关键字,而且语法很简单:desc tablename;
复制代码
单列排序:4 E+ G# p% D* }: o7 o! ^8 M

6 p1 u( k7 H. {* Q6 Z8 ?: S! v! m多列排序:用符号 “,” 隔开即可3 U0 Q# P: U% R

0 ?. v& ^% g+ r, l3 K( b* p7 O# H4 m8 }/ r) n
5.5.limit查询+ x! u2 I' V8 o/ h' q. j; p) D
4 A7 D; @, f# X1 u
  又称为限制查询、范围查询、分页查询
  1. --最简单的limit查询:offset_start和数组下标一样,从0开始算select * from tablename limit offset_start,row_count;--完整语法:这条sql是单表查询的完整版select [field1,field2,...,fieldn] fun_name from tablename [where condition] [group by field1,field2,...,fieldn [with rollup]] [having condition] [order by field1 [desc|asc], field2 [desc|asc],...,fieldn [desc|asc]] [limit offset_start,row_count];
复制代码
例子1:从第1条开始,查询两条数据8 [5 R! J9 [+ E( p  ?
例子2:从第2条开始,查询两条数据! X' Y& j" f0 Q
# R+ S5 o4 X- \9 {- Q1 A6 H
=========================) I# {+ e1 y- j* c  q0 [
= 以上就是关于单表查询的语法 =
" T7 Z/ ^( i2 d= 以下则是关于两表联查的语法 =
# J' O% @4 y6 K# Y* b2 o=========================
) K9 X4 ^8 z3 z7 U6 Y* L6 S3 i& U( d* w2 Y$ q% G* y
5.6.连表查询" F4 I$ b) t) O; r, j) M

0 i5 T! B9 s5 N: V: ?& o在需要关联多个表数据时使用。 学习左连接和内连接即可。
" M: T( ^" J! F) h! [) y! ~# H左连接:选出左表所有的记录,不管右表有没有和它匹配;左表是主,关联右表信息
  1. select * from t1 left join t2 on t1.field1=t2.field2;
复制代码
内连接:仅选出两张表中互相匹配的记录,没有匹配则结果为空
  1. select * from t1 inner join t2 on t1.field1=t2.field2;select * from t1,t2 where t1.field1=t2.field2;
复制代码

* l: c. n1 m/ [* Q
* {/ g1 h  r1 ~/ Q& {" n5.7.子查询: |/ T+ Z( ^. q1 U
1 N4 R" \2 f% O* J9 G- @- F
在需要另外一个查询结果作为查询条件时使用。子查询用“()” 括起来。
. {% t5 X9 R- [5 ~% W如:查询学生“张三”的成绩) y4 `; k2 ]# x) \  e( F  N8 `

3 A# r* @6 z8 v0 k/ L4 I9 Y某些情况下,子查询可以转化为连表查询。如上面的例子可以写成连表查询:* g( g2 \9 r7 h! [3 o

& W& O( a  q# F8 G8 y6 E6 z. P- B/ d2 U3 z, c
5.8.记录联合/ z8 w. v- Q* N6 o: m% |# p" e
2 h& Y5 ^4 J( y7 D1 V3 ?
 将两个过多个表的查询结果合并成结果集输出。合并的条件是多个表的查询结果字段数要相同,注意是查询结果字段数不是表字段数。
  1. select f1,f2,...,fn from t1union/union allselect f1,f2,...,fn from t2...union/union allselect f1,f2,...,fn from tn
复制代码
4 N# e% z+ k" Q3 x7 @/ I
查询结果字段数不等,则报错
. W. X, e, J) w1 q' i8 n( x. [1 n5 k5 E

4 S7 B8 C) R5 V' H. p固定查询结果集字段数
( ^7 \! O* y7 {1 L/ G

  d. ^9 z& V- C# {- u* D" ]. ]/ c: H. j$ i
5.9.select语句的执行顺序7 a6 `1 Z: P( z( Z4 D" Z
  q' X0 k! J9 N8 E
自行证明该执行顺序是否正确,也算是对前面所学知识的一个巩固。​
/ d' Z, X: a5 I/ E0 E6 I
(7)  SELECT 
: K  `1 B4 w7 }+ [9 i( W(8)  DISTINCT
- r6 Y& S4 i0 |( X( t(1)  FROM / _  x8 A1 ?6 `4 Y4 E( B* y
(3)   JOIN ' D& K& j; e3 [6 o( Y
(2)  ON
5 r& N- f) j( b8 b+ p(4)  WHERE : i6 c6 X) C7 B0 m
(5)  GROUP BY
. V' j2 y1 O' I1 [(6)  HAVING ! y$ s! c9 {$ O1 S1 p- K
(9)  ORDER BY
" ~- G4 u9 e, Z, ~0 q" v(10) LIMIT ​
* d$ M7 G6 R* ?; @% p
5 ?& H3 v+ w" k2 d' ?* \
6.总结
0 X; ?+ ~& R% P6 u* f. A, C# A
. r6 v4 T3 G6 a( b" V, J到此为止,关于日常操作最为频繁的表数据的插入(insert)、更新(update)、删除(delete)和查询(select)语句就讲完了。最为繁杂的查询语句,又名为DQL语句,是DML语句中的重点。! Q5 ?6 y: b& E
到此这篇关于MySQL基础教程之DML语句的文章就介绍到这了,更多相关MySQL基础之DML语句内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
2 |4 N- p* `  b2 Z& o! H1 X
" |" R6 {& A' l1 R来源:http://www.jb51.net/article/232467.htm
: h+ Z9 X1 h5 M" I2 K. ^  k免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

帖子地址: 

梦想之都-俊月星空 优酷自频道欢迎您 http://i.youku.com/zhaojun917
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2026-4-28 01:41 , Processed in 0.043041 second(s), 24 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表