本文共 1889 字,大约阅读时间需要 6 分钟。
结构化查询语言(Structured Query Language)简称SQL,结构化查询语言是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统:同时也是数据库脚本文件的扩展名。结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存取方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统,可以实用相同的结构化查询语言作为数据输入与管理的接口。结构化查询语言可以嵌套,这使得它具有极大的灵活性和强大的功能。
DML(数据库操作语言):
其语句包括动词INSERT,UPDATE和DELETE。它们分别用于添加,修改和删除表中的行。也称为动作查询语言。DDL(数据库定义语言):
其语句包括动词CREATE和DROP。在数据库中创建新表或删除表(CREATE TABLE 或 DROP TABLE):为表加入索引等。DDL包括许多与数据库目录中获得数据有关的保留字。它也是动作查询的一部分。DCL(数据库控制语言):
它的语句通过GRANT 或 REVOKE 获得许可,确定单个用户和用户组对数据库对象的访问。某些RDBMS可用GRANT或REVOKE控制对表单个列的访问。SELECT *|{ [DISTINCT] column|expression [alias],...}FROM table;
当前用户下的表:
select * from tab;
查询表结构
SQL> desc emp
select * from emp;
select empno,ename,job,mgr,hiredate,sal,comm,deptnofrom emp;
三种写法的区别:
其中第1种和第2种完全相同。 第3种写法无法包含空格、无法为纯数字select empno as "员工号",ename "雇员名",job 工作 from emp;
消除重复数据
注意:distinct关键字作用于后面所有的列,即只要列组合起来唯一即可。select distinct job from emp;
select ename,sal,sal*12 年薪 from emp;
查询雇员的姓名、月薪、奖金、年薪和年收入(年薪+奖金)
select ename,sal,comm,sal*12 年薪,sal*12+comm 年收入from emp;
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
sql修改为:
select ename,sal,comm,sal*12 年薪,sal*12+nvl(comm,0) 年收入from emp;
select * from emp where comm is null;
字符串:
查询员工信息:*** 的薪水是 ***
select ename||'的薪水是'||sal 信息 from emp;
转载地址:http://mjsqb.baihongyu.com/