2024-03-19  阅读(7)
原文作者:吴声子夜歌 原文地址: https://blog.csdn.net/cold___play/article/details/100632727
sql简介

结构化查询语言(Structured Query Language)简称SQL,结构化查询语言是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统:同时也是数据库脚本文件的扩展名。结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存取方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统,可以实用相同的结构化查询语言作为数据输入与管理的接口。结构化查询语言可以嵌套,这使得它具有极大的灵活性和强大的功能。

  • DML(数据库操作语言):
    其语句包括动词INSERT,UPDATE和DELETE。它们分别用于添加,修改和删除表中的行。也称为动作查询语言。
  • DDL(数据库定义语言):
    其语句包括动词CREATE和DROP。在数据库中创建新表或删除表(CREATE TABLE 或 DROP TABLE):为表加入索引等。DDL包括许多与数据库目录中获得数据有关的保留字。它也是动作查询的一部分。
  • DCL(数据库控制语言):
    它的语句通过GRANT 或 REVOKE 获得许可,确定单个用户和用户组对数据库对象的访问。某些RDBMS可用GRANT或REVOKE控制对表单个列的访问。
Select语句的语法格式
    SELECT *|{[DISTINCT] column|expression [alias],...}
    FROM table;

当前用户下的表:

    select * from tab;

202403192031128521.png

查询表结构

    SQL> desc emp

202403192031131142.png
查询所有员工信息

    select * from emp;

202403192031133943.png
通过列名查询
SQL优化:使用列名查询效率高于使用 * 查询。

    select empno,ename,job,mgr,hiredate,sal,comm,deptno
    from emp;

202403192031138104.png
别名的用法
别名的用法共有三种:

  1. as “xxx”
  2. “xxx”
  3. xxx

三种写法的区别:
其中第1种和第2种完全相同。
第3种写法无法包含空格、无法为纯数字

    select empno as "员工号",ename "雇员名",job 工作 
    from emp;

202403192031143695.png

消除重复数据
注意:distinct关键字作用于后面所有的列,即只要列组合起来唯一即可。

    select distinct job from emp;

202403192031147656.png
查询中的四则运算
查询雇员的月薪和年薪

    select ename,sal,sal*12 年薪 from emp;

202403192031150417.png
空值问题
什么空值:

  1. 空值是无效的,未指定的,未知的或不可预知的值。
  2. 空值不是空格或者0.

查询雇员的姓名、月薪、奖金、年薪和年收入(年薪+奖金)

    select ename,sal,comm,sal*12 年薪,sal*12+comm 年收入
    from emp;

202403192031153598.png
由上图可知,查询结果显然是不对的。因为不可能出现年收入为空值的情况。
进一步观察可以发现,年收入为空值的奖金也是空值。

SQL中的null:
4. 包 含 n u l l 的 表 达 式 都 为 空 \color{red}{包含null的表达式都为空} 包含null的表达式都为空
5. n u l l 永 远 ! = n u l l \color{red}{null永远 != null} null永远!=null

解决方法:滤空函数 nvl 和nvl2

  • nvl
    NVL(E1, E2)的功能为:如果E1为NULL,则函数返回E2,否则返回E1本身。
  • nvl2
    NVL2(E1, E2, E3)的功能为:如果E1为NULL,则函数返回E3,若E1不为null,则返回E2。

sql修改为:

    select ename,sal,comm,sal*12 年薪,sal*12+nvl(comm,0) 年收入
    from emp;

202403192031156299.png
查询空值
查询奖金为null的雇员信息

    select * from emp where comm is null;

2024031920311593810.png
连接符 ||
连接符:

  • 把列与列,列与字符连接在一起。
  • 用“ || ” 表示。
  • 可以用来‘合成’列。

字符串:

  • 字符串可以是SELECT列表中的一个字符,数字,日期。
  • 日 期 和 字 符 只 能 在 单 引 号 中 出 现 。 \color{red}{日期和字符只能在单引号中出现。} 日期和字符只能在单引号中出现。
  • 每当返回一行时,字符串被输出一次。

查询员工信息:*** 的薪水是 ***

    select ename||'的薪水是'||sal 信息 from emp;

2024031920311629711.png


Java 面试宝典是大明哥全力打造的 Java 精品面试题,它是一份靠谱、强大、详细、经典的 Java 后端面试宝典。它不仅仅只是一道道面试题,而是一套完整的 Java 知识体系,一套你 Java 知识点的扫盲贴。

它的内容包括:

  • 大厂真题:Java 面试宝典里面的题目都是最近几年的高频的大厂面试真题。
  • 原创内容:Java 面试宝典内容全部都是大明哥原创,内容全面且通俗易懂,回答部分可以直接作为面试回答内容。
  • 持续更新:一次购买,永久有效。大明哥会持续更新 3+ 年,累计更新 1000+,宝典会不断迭代更新,保证最新、最全面。
  • 覆盖全面:本宝典累计更新 1000+,从 Java 入门到 Java 架构的高频面试题,实现 360° 全覆盖。
  • 不止面试:内容包含面试题解析、内容详解、知识扩展,它不仅仅只是一份面试题,更是一套完整的 Java 知识体系。
  • 宝典详情:https://www.yuque.com/chenssy/sike-java/xvlo920axlp7sf4k
  • 宝典总览:https://www.yuque.com/chenssy/sike-java/yogsehzntzgp4ly1
  • 宝典进展:https://www.yuque.com/chenssy/sike-java/en9ned7loo47z5aw

目前 Java 面试宝典累计更新 400+ 道,总字数 42w+。大明哥还在持续更新中,下图是大明哥在 2024-12 月份的更新情况:

想了解详情的小伙伴,扫描下面二维码加大明哥微信【daming091】咨询

同时,大明哥也整理一套目前市面最常见的热点面试题。微信搜[大明哥聊 Java]或扫描下方二维码关注大明哥的原创公众号[大明哥聊 Java] ,回复【面试题】 即可免费领取。

阅读全文