zoukankan      html  css  js  c++  java
  • 数据库的高级操作

    高级操作

    复制表结构

    语法:

        create table 表B like 表A;

    示例:

    复制表中的数据

    语法:

        create table 表B select *或字段列表 from 表A;

    蠕虫复制

    语法:

        insert into 表名【(字段列表)】 select *或字段列表 from 表名;

    修改操作

        限制修改指定的行数。

    语法:

        update 表名 set 字段=值... 【where子句】 limit n;

    说明:

        在执行update语句时,限制最多修改n行

    示例:

    删除操作

        限制删除的行数

    语法:

        delete from 表名 【where 子句】 limit n;

    说明:

        用于限制最多只能删除n条记录

    示例:

    插入操作

    主键冲突

    基本语法:

        insert into 表名【(字段列表)】 values(值列表);

    主键冲突

        insert into 表名【(字段列表)】 values(值列表) on duplicate key update 字段=值,字段=值...;

    示例:

    说明:

        主键冲突的方式也可应用在唯一键冲突。

    唯一键冲突

    同理

    replace into 表名【字段列表】 values(值列表);

    说明:

        在主键冲突或唯一键冲突时,替换冲突的记录

    示例:

    查询操作

    标准语法:

        select 【all|distinct】 *|字段列表|字段名 【as】 别名 from 数据源 【where子句】【group by子句】【having子句】【order by 子句】【limit子句】

     

    说明:

    select选项

        all(缺省)    表示显示所有的记录(包含重复的记录)

        distinct        表示不显示重复的记录(去掉重复记录)

    示例:

    字段别名

    语法:

        字段名 【as】 别名

    示例:

    说明:

        只是在显示的更改字段的名子,并没有更改表结构中的字段的名子。

        一般是用在多表查询时

    表别名

    语法:

        from 表名 【as】 表别名

    示例:

     

    数据源

    数据的来源,数据的来源可以分3种:

    1、单表数据源

        select * from 表名;

    2、多表数据源

        select * from 表A,表B;

    说明:

        将多个表的字段进行横向连接,

        记录数相乘

        术语:迪卡尔积

    示例:

    3、子查询数据源

    select语句查询的结果是一个结果集,那再将此结果集作为from的一个数据源,此种数据源即为子查询数据源

    示例:

    说明:

        子查询数据源,必须将子查询使用括号括起来,并且设置一个别名

    【where子句】

    根据条件进行数据筛选,条件即为一个表达式,表达式就需要运算符

    is null

    is not null

    <=>安全相等    专用于判断null,只适用于MySQL SQL Server不适用

    between

        between m and n

        介于m与n之间(包含m与n)

    in

    like

        %        表示当前位置及其后所有的字符

        _        只表示当前位置的字符

    where原理

    首先明确:计算机数据存储磁盘,运算在内存中。

    where就是将存储磁盘中的数据,读取到内存,并根据条件进行筛选。如果省略where,则表示所在记录都匹配

    图解:

     

    【group by子句】

        作用是根据group by的条件进行分组,就是一个大的结果集,划分为多个小区域,再进行统计

    简单分组:

    说明:

        group by虽然是分组的意义,但group by 更重要的作用是对大的结果集中的小区域进行统计。

    group by的原理

    更改分组排序

    示例:

    需求,每一组中价格最高的商品

    错误示例:由于order by 是根据 group by之后的结果再行排序,

    解决办法,在分组之前就对原数据进行排序。

    统计函数(聚合函数)

        group by 最主要的作用是对分组的小区域进行统计

    count();

    统计显示结果中记录数

    语法:

        count(*|字段名);

    说明:

        *:表示统计所有的记录数

        字段名:根据字段名进行统计记录数

     

    示例1:

    示例:

        

    max();

        统计最大值

    示例:

    min();

        统计最小值

    示例:

    avg();

        统计平均值

    示例:

    sum();

        统计和

    示例:

    分组统计:

    示例1:

    示例2:

    多字段分组

        group by可以对多字段进行分组

    语法:

        group by 字段1,字段2;

    说明:

        先使用字段1对结果集进行分组,再使用字段2在分组的结果中再进行分组。有几个字段相当于分了几层。

    示例:

    图解:

    对多字段进行分组并统计时,统计函数是应用在最小组

    示例:

    with rollup(回溯)

        使用汇总,对多个字段进行分组时所产生的多个层级的组,由里向外再应用统计函数。

    示例:

    原理图:

    【having子句】

    作用:

        对group by分组后的结果再进行筛选。

     

    where能够实现的having也能够实现,但是having能实现的,where不一定能实现

    示例:

    where 的效率高于having。

    having可以使用统计函数,但是where不可以使用统计函数。

    说明:

        统计函数是对分组后的数据进行再次统计。在where执行过程中,结果集还没有完成生成,所以无法应用统计函数。

     

    【order by 子句】

    按指定的字段对数据进行排序

    asc        升序

    desc    降序

    【limit子句】

        限制数据的操作(显示、更新、删除)

     

    外键

        外键,就是外面的键。

        为了某种需求,表A中的某个字段是表B中的主键,那么该字段叫表B的外键。

    需求,有两个表,学生表与班级表,学生与班级有关系。如下:

    虽然两个表建立关系,但并没有实质的约束存在,如下:

    为了解决此种问题,必须使用外键约束。

    创建外键:

    条件:

        前提外键所附属的表必须先存在

        外键字段必须所附属表的主键

        字段的类型一定要相同。

    语法1:在创建表时创建外键。

        foreign key(字段) references 表名(字段名)

    示例:

    语法2:通过修改表结构,创建外键

    查看外键

    show create table 表名;

    示例:

    删除外键

    语法:

        alter table 表名 drop foreign key 外键名;

    示例:

    使用外键

    1、向class插入数据

    2、向stu表中插入数据

    外键的约束

    class为主表,stu为从表

    主表被从表约束

    1、对主表的数据进行操作时(update与delete),不能违反外键约束。

    示例:

    2、如果主表与从表建立了外键约束,那么主表不能被删除

    示例:

    从表被主键约束

    向从表中插入数据时,外键字段,必须是主表中主键字段已有的数据。

    置空约束

        on delete set null

        当删除主表中的记录时,从表中与之有关联的记录的外键自动设置为null

    级联约束

        on update cascade

        当对主表中的记录的主键字段进行更改时,从表中的与之关联的外键同步更新。

    示例:

        添加置空与级联约束

    添加数据:

    insert into stu values(default,'php007','lisi',30,'cls001');

    insert into stu values(default,'php008','wang',30,'cls002');

    insert into stu values(default,'php009','zhao',30,'cls003');

    insert into stu values(default,'php009','zhao',30,'cls001');

    尝试删除与更新

  • 相关阅读:
    条件
    循环
    列表
    字典
    集合
    公共操作
    函数-2
    函数-1
    函数加强
    文件操作
  • 原文地址:https://www.cnblogs.com/nyxd/p/5357045.html
Copyright © 2011-2022 走看看