5、mysql表内容操作

作者: go以恒 | 来源:发表于2018-09-15 23:43 被阅读1次

    [toc]

    表内容操作

    1、增

    • insert into 表 (列名,列名...) values (值,值,值...)
    • insert into 表 (列名,列名...) values (值,值,值...),(值,值,值...)
    • insert into 表 (列名,列名...) select (列名,列名...) from 表

    2、删

    • delete from 表
    • delete from 表 where id=1 and name='alex'

    3、改

    • update 表 set name = 'alex' where id>1

    4、查

    • select * from 表
    • select * from 表 where id > 1
    • select nid,name,gender as gg from 表 where id > 1

    5、其他

    a、条件

    • select * from 表 where id > 1 and name != 'alex' and num = 12;
    • select * from 表 where id between 5 and 16;
    • select * from 表 where id in (11,22,33)
    • select * from 表 where id not in (11,22,33)
    • select * from 表 where id in (select nid from 表)

    b、通配符

    ale开头的所有(多个字符串)

    • select * from 表 where name like 'ale%'

    ale开头的所有(一个字符)

    • select * from 表 where name like 'ale_'

    c、限制

    前5行

    • select * from 表 limit 5;

    从第4行开始的5行

    • select * from 表 limit 4,5;

    从第4行开始的5行

    • select * from 表 limit 5 offset 4

    d、排序

    根据 “列” 从小到大排列

    • select * from 表 order by 列 asc

    根据 “列” 从大到小排列

    • select * from 表 order by 列 desc

    根据 “列1” 从大到小排列,如果相同则按列2从小到大排序

    • select * from 表 order by 列1 desc,列2 asc

    e、分组

    ==group by 必须在where之后,order by之前==

    ==条件语句包含函数的不能用where,只能用having==

    • select num from 表 group by num
    • select num,nid from 表 group by num,nid
    • select num,nid from 表 where nid > 10 group by num,nid order nid desc
    • select num,nid,count(*),sum(score),max(score),min(score) from 表 group by num,nid
    • select num from 表 group by num having max(id) > 10

    f、连表

    A、B表有的都显示

    select A.num, A.name, B.name
    from A,B
    Where A.nid = B.nid
    

    只显示A、B表都有的

    ==inner join==

    select A.num, A.name, B.name
    from A inner join B
    on A.nid = B.nid
    

    A表所有显示,如果B中无对应关系,则值为null

    ==left join==

    select A.num, A.name, B.name
    from A left join B
    on A.nid = B.nid
    

    B表所有显示,如果B中无对应关系,则值为null

    ==right join==

    select A.num, A.name, B.name
    from A right join B
    on A.nid = B.nid
    

    g、组合

    组合,自动处理重合

    ==union==

    select nickname
    from A
    union
    select name
    from B
    

    组合,不处理重合

    ==union all==

    select nickname
    from A
    union all
    select name
    from B
    

    h、聚合函数

    • 计数: count
    • 最大值: max
    • 最小值: min
    • 求和: sum
    • 平均值: avg

    相关文章

      网友评论

        本文标题:5、mysql表内容操作

        本文链接:https://www.haomeiwen.com/subject/ujcxnftx.html