数据库系统原理之SQL(四)


1. 数据更新

插入数据

  1. INSERT…VALUES语句

    #插入多条数据
    insert [into] table_name (column_name,...) values ({expr | DEFAULT},...),{....}
    expr:可以是常量、变量、表达式、也可以是null
    DEFAULT:该列的默认值
  2. INSERT…SET语句

    #插入一条数据
    insert [into] table_name set column_name="张三",column_age=12
  3. INSERT…SELECT语句

    #插入子查询出的数据,子查询的字段数量数据类型要和插入表的字段一致
    insert [into] table_name [(column_name,...)] select
  • 删除数据

    DELETE FROM table_name [WHERE where_condition] [ORDER BY …] [LIMIT row_count]
  • 修改数据

    #修改数据,字段=值,条件,
    UPDATE table_name SET column_name={expr1|DEFAULT} [,col_name2={expr2|DEFAULT}]
    [WHERE where_condition] [ORDER BY …] [LIMIT row_count]
  • 查询数据

    1. SELECT 语句

      SELECT [ ALL | DISTINCT | DISTINCTROW ]
      select_expr[,expr...] -- 需要查询的字段
      FROM table_name -- 查询的表,数据来源
      [where where_condition] -- 查询条件
      [GROUP BY {column_name | expr | position } -- 对查询的数据分组,
      [ASC|DeSC],...[WITH ROLLUP]]
      [HAVING where_condition] -- 指定组的选择条件
      [ORDER BY {column_name | expr | position } -- 对查询的结果进行排序
      [ASC | DESC ]...]
      [LIMIT {[offset row_count | row_count OFFSET offset }] -- 限制行数
    2. 别名

      • 用select查询的时候可以为查询的字段设置别名,如:

        SELECT class_name as name from class

        查询班级名称并为字段class_name设置别名name

      • 可以为表设置别名,如:

        SELECT * FROM t_class as class where class.name="张三"

        查询班级里面名字是张三的人,from的时候设置t_class的别名是class ,后面就可以直接使用别名

    3. 替换查询结果集中的数据

      • 查询班级中同学的信息,并且把0代表女,1代表男,直接输出中文

        SELECT id,name,age,
        case
        where sex=0 then "女" -- 如果sex是1,则输出女
        where sex=1 then "男" -- 如果sex是0,则输出男
        else "未确定" --否正输出未确定
        end [as] "性别" -- 设置别名为性别
        from class
    4. 交叉连接,又称笛卡尔积

      select * from table_1 [CROSS JOIN] table_2
    5. 内连接,inner join ....on

      -- 需要inner join连接用on连接两张表的外键,以形成连接关系
      select * from table_1 inner join table_2 on table_1.A=table_2.A
    6. 外连接——左外连接(以左边表为基表)left join

      select * from table_1  left join table_2 on table_1.A=table_2.A
    7. 外连接——右外连接(以右边表为基表)right join

      select * from table_1  right join table_2 on table_1.A=table_2.A
    8. where子句条件查询

      • between,把查询范围确定在某个范围内

        -- 查询年龄在18到20之间的学生
        select * from students where age between 18 and 20
      • in,列出所有指定条件的值

        -- 查询年龄是18,19,20的学生
        select * from students where age in (18,19,20);
        -- 查询任意所选课程成绩高于80分的学生的学号和姓名信息
        SELECT studentNo,studentName
        FROM tb_student
        WHERE studentNo IN(SELECT studentNo FROM tb_score WHERE score›80);
    9. Group By 子句

      select * from students group by class
    10. HAVING子句(过滤分组)查询班级人数大于60的学生

      select * from students group by class having count(*) >= 60
    11. order by子句,排序。ASC升序,DESC降序

      SELECT * FROM students ORDER BY age DESC,score DESC;
    12. limit 子句,从第6个同学查询出10个同学

      select * from students limit 5,10

数据库系统原理之SQL(四)的更多相关文章

  1. 数据库系统原理之SQL(三)

    数据库系统原理之SQL(三) 1. SQL的组成 1. 数据查询 2. 数据定义 3. 数据操作 4. 数据控制 2. 数据定义语言 CREATE创建数据库或数据库对象 创建数据库 ~~~ CREAT ...

  2. 数据库系统原理(第四章:SQL与关系数据库基本操作 )

    一.SQL概述 sql是结构化查询语言(Structured Query Language,SQL)是专门用来与数 据库通信的语言,它可以帮助用户操作关系数据库. SQL的特点: SQL不是某个特定数 ...

  3. Atiti 数据库系统原理 与数据库方面的书籍 attilax总结 v3 .docx

    Atiti 数据库系统原理 与数据库方面的书籍 attilax总结 v3 .docx 1.1. 数据库的类型,网状,层次,树形数据库,kv数据库.oodb2 1.2. Er模型2 1.3. Sql2 ...

  4. php面试专题---Mysql索引原理及SQL优化

    php面试专题---Mysql索引原理及SQL优化 一.总结 一句话总结: 注意:只写精品 1.为表设置索引要付出代价 是什么? 存储空间:一是增加了数据库的存储空间 修改插入变动索引时间:二是在插入 ...

  5. 数据库系统原理——ER模型与关系模型

    原文链接: http://blog.csdn.net/haovip123/article/details/21614887 犹记得第一次看<数据库系统原理>时看天书的感觉,云里雾里:现在已 ...

  6. JAVA-Unit01: 数据库原理 、 SQL(DDL、DML)

    Unit01: 数据库原理 . SQL(DDL.DML) SQL语句是不区分大小写的,但是行业里习惯将关键字与分关键字用大小写岔开以提高可读性. SELECT SYSDATE FROM dual DD ...

  7. WebSocket原理与实践(四)--生成数据帧

    WebSocket原理与实践(四)--生成数据帧 从服务器发往客户端的数据也是同样的数据帧,但是从服务器发送到客户端的数据帧不需要掩码的.我们自己需要去生成数据帧,解析数据帧的时候我们需要分片. 消息 ...

  8. Vue双向绑定的实现原理系列(四):补充指令解析器compile

    补充指令解析器compile github源码 补充下HTML节点类型的知识: 元素节点 Node.ELEMENT_NODE(1) 属性节点 Node.ATTRIBUTE_NODE(2) 文本节点 N ...

  9. RocketMQ架构原理解析(四):消息生产端(Producer)

    RocketMQ架构原理解析(一):整体架构 RocketMQ架构原理解析(二):消息存储(CommitLog) RocketMQ架构原理解析(三):消息索引(ConsumeQueue & I ...

随机推荐

  1. Django初使用

    目录 一.Django初使用 1. 静态文件配置 (1)静态文件配置步骤 2. form表单的get和post提交方式 (1)get (2)post (3)注意 3. views文件中的request ...

  2. k-means伪代码

    1.初始化k个簇中心. 2.更新所有样本点簇归属:样本点到哪个簇中心点最近就属于哪个簇. 3.重新计算每个簇的中心点(直到簇中心点不再变化或达到更新最大次数) #k-means伪代码 import n ...

  3. 一种循环C字符数组的骚操作

    #include <stdio.h> #include <stdlib.h> int main() { char wenwa[] = "程劲小盆友在做什么" ...

  4. Tomcat网站上的core和deployer的区别

    8.5.13 Please see the README file for packaging information. It explains what every distribution(分布) ...

  5. 数据库基本概念及Oracle基本语句

    一.数据库分类 通常是按照数据模型的特点将传统数据库系统分成网状数据库.层次数据库和关系数据库三种. 1.网状数据库 顾名思义,网状数据库采用的是以记录类型为结点的网状数据模型,是一种导航式(Navi ...

  6. python list颠倒写法

    a=[1,2,3,4] a[::-1] ...... [4,3,2,1]

  7. Python Number(数字) Ⅱ

    Python math 模块.cmath 模块 Python 中数学运算常用的函数基本都在 math 模块.cmath 模块中. Python math 模块提供了许多对浮点数的数学运算函数. Pyt ...

  8. SpringBoot搭建基于Apache Shiro的权限管理功能

    Shiro 是什么 Apache Shiro是一个强大易用的Java安全框架,提供了认证.授权.加密和会话管理等功能: 认证 - 用户身份识别,常被称为用户“登录”: 授权 - 访问控制: 密码加密 ...

  9. UVa 1602 Lattice Animals (STL && 生成n连块 && 无方向形状判重)

    题意 : 给定一个 w * h 的 矩阵,在矩阵中找不同n个连通块的个数(旋转,翻转,平移算作一种) 分析 : 这题的关键点有两个 ① 生成n连块并且存储起来(因为题目是多测试用例,如果每一次都重新生 ...

  10. [luogu]P1514 引水入城[搜索][记忆化][DP]

    [luogu]P1514 引水入城 引水入城 题目描述在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N 行M 列的矩形 ,如下图所示,其中每个格 ...