SQL语言详解——基于PLSQL的SQL语言详解


注:本文基于Oracle数据库与数据库管理软件plsql,文中代码里使用的大部分表格为该软件的测试用户SCOTT下的默认表格
文中代码格式使用到<>表示必写项,[]表示可选项

2.1 SQL语言基础

  • 什么是SQL语言
    • 结构化查询语言SQL(Structured Query Language)
    • SQL是最重要的关系数据库操作语言,是所有关系数据库管理系统的标准语言
    • 许多数据库厂商在使用SQL的同时,都对SQL进行了拓展,比如ORACLE的PL/SQL语言,MSSQL-Server的T-SQL语言
    • SQL语言是一种非过程化的语言,只需要提出做什么,不需要提出怎么做
  • SQL可以做什么
    • 数据库的增删改查操作(CRUD)
    • 数据库对象的创建,修改和删除操作(用户,表格,序列,索引…)
    • 用户权限/角色的授予与取消
    • 事务控制
  • SQL语言的分类
    • DQL,Data Query Language,数据查询语言,执行数据库的查询操作:select
    • DML,Data Manipulation Language,数据操作语言,执行增删改的操作:insert,delet,update
    • DDL,Data Definition Language,数据定义语言,用于操作数据库对象:add,modify,drop
    • DCL,Data Control Language,数据控制语言,操作用户权限:grant(授予),revoke(撤销)
    • TCL,Transaction Control Language,事物控制语言,用于管理事物:commit ,rollback
  • 关系数据库的基本名词解释
    • 关系:整个二维表
    • 关系名:表格名称
    • 元组:行数据(记录)
    • 属性:列数据(字段)
    • 属性名:列名称(字段名)
    • 主键:唯一确定元组的属性组(关键字)
    • 域:
  • SQL语言的执行顺序 form–where–group by–select–having–order by

2.2 Select子句

  • 使用“–”来注释
  • 查询某张完整表格,其中表示“*”表示获取所有的列
select * from <表格名>;
  • 按字段名查询某张表格
select <字段名1>,<字段名2> from <表格名>;
  • 查询并临时修改一个字段名
    • 其中as可省略
    • 如新名称中有空格,则新名称需要使用双引号才不会报错
    • SQL中双引号表示原样输出,如双引号中的小写字母不会转换成大写字母
select <字段名> as <新名称> form <表格名>;
  • 查询员工月薪并做简单运算得到年薪,新命名为年薪
select sal*12 年薪 from emp;

2.4 distinct_字符串连接符_order by

  • distinct去除重复行
    • 译作 独特的,明显的,有区别的
    • 作用范围为distinct后面的列,可以是单列、多列和所有列
    • 举例:
    select distinct job from emp; //去除job这一列中重复的两行中的一行并展示之
    select distinct job,mgr from emp; //去除job与mgr两列中完全相同的两行中的一行并展示之
    select distinct * from emp; //去除所有列中完全相同的两行中的一行并展示之
    
  • 字符串连接符 “||”
    • 举例:查询所有员工的姓名、职位和薪资,按格式输出:“”并作为单独的一列,列名称为INFO
    select '姓名:'||ename||' 职位:'||job||' 薪资:'||sal info from emp;
    //单引号必须为英文半角
    
  • order by子句
    • order by子句用于排序
    • 升序举例:查询并按薪资升序(升序asc,asc可以省略不写)
    select * from emp order by sal asc;
    
    • 降序举例:查询并按薪资降序(降序desc)
    select * from emp order by sal desc;
    
    • 多条件排序举例:按薪资降序排序,如果薪资相同,按入职时升序排序
    select * from emp order by sal desc,hiredate asc;
    

2.5 where子句——条件过滤

使用where子句过滤来查询内容

2.5.1 等值条件和非等值条件

-等值判断

  • 查询工资等于800的记录
select * from emp where 
  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值