您的位置:首页 > 数据库 > Oracle

原创:oracle:sql介绍及SQL基本查询 (四)

2011-04-13 21:47 501 查看
    SQL是structured Query
Language(结构化查询语言)的缩写。可以使用sql语句建立或删除数据库的对象,插入,修改和更新数据库中的数据,并且可以对数据库执行各种日常管理的操作。它是所有关系数据库管理系统的标准语言.换句话说使用sql可以对所有的关系数据库进行操作。

   SQL按照功能分类:

1、 数据库定义语句

DDL(Data Definition
Language):用于创建、修改、删除数据库对象。

2、 数据库操作语句

DML(Data Manipulation
Language)用于:查询,添加修改或删除存在数据库对象中的数据。

3、 数据库控制语句DCL

DCL(Data Control
Language)用于控制访问数据库中特定对象的用户、grant revoke

Oracle系统中经过对Sql语言扩展被称为PL/SQL语言。

 

 

基本的sql语句

SELECT    *|{[DISTINCT] column|expression [alias],...}

FROM    table;

ORACLE基本语句的查询与使用

SQL> select * from emp;//查询所有的字段信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp;//查询所有

SQL> select empno from emp;//查询部分字段

SQL> select empno "员工编号" from emp;//采用别名查询

SQL> select empno as "员工编号" from emp;//采用别名查询 等效于上面的效果

SQL> select distinct(hiredate) from emp;//查询所有员工的入职日期并且去掉重复的日期

SQL> select sal+comm from emp;//注意:包含空值的数学表达式求出的结果为空值

SQL> select empno||ename from emp;//||连接符 把empno与ename作为一个字段显示

SQL> select empno||ename  as "员工编号和员工姓名" from emp;//效果同上

SQL> select '员工的编号是'||empno from emp;//字符的链接

SQL> select '姓名为'||ename||'员工,所在的部门是:'||deptno as "新列" from emp;//字段的链接包号字符连接

SQL> select distinct(deptno) from emp;//查询去掉(部门编号)重复的行

条件查询

SELECT    *|{[DISTINCT] column|expression [alias],...}

FROM    table

[WHERE    condition(s)];

Condition(s)要使用到比较运算符常用的比较运算符如下:

操作符    含义

=    等于

>    大于

>=    大于等于

<    小于

<=    小于等于

<>    不等于 等效于!=

其它操作

And 逻辑运算  逻辑与

Or  逻辑运算  逻辑或

Not 逻辑运算  逻辑否

Between 起始值 and 结束值:使用 BETWEEN 运算来显示在一个区间内的值 包含(起始结束值)

In: 使用 IN运算显示列表中的值。 In(,,,)相当于一个集合,只要出现集合中匹配的就显示

Like:

    使用 LIKE 运算选择类似的值

    选择条件可以包含字符或数字:

•    % 代表零个或多个字符(任意个字符)。

•    _ 代表一个字符。

Escape:

   回避特殊符号的:使用转义符。例如:将[%]转为[/%]、[_]转为[/_],然后再加上[ESCAPE ‘/’] 即可

Null:

使用 IS (NOT) NULL 判断空值。

//查询部门号为10的员工信息  部门为整数类型

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno=10;

//查询职位号为MANAGER的员工信息  岗位的类型为字符类型

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where job='MANAGER';

//查询部门号为10并且员工的职位为MANAGER的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where job='MANAGER' and deptno=10;

注意:

    字符和日期要包含在单引号中。

    字符大小写敏感,日期格式敏感。

    默认的日期格式是 DD-MON-RR。

   

Where子句使用比较运算符:'>'(大于),'>='(大于等于),'='(等于),'<='(小于等于)'<'(小于).'<>'(不等于).'!>'(不大于).'!<'(不小于)

//查询部门号大于10的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno>10;

//查询薪水大于等于3000的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>=3000;

//查询薪水不等于3000的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal<>3000;

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal !=3000;

//查询薪水大于2000并且小于3000的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>2000 and sal<3000;

//查询薪水大于等于2000并且小于等于3000的员工信息

逻辑运算符的使用:'and','or','not'

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal between 1600 and 3000;

//等效于

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>=1600 and sal<=3000;

//查询部门号位10,20的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno in(10,20);

//注意:相当于如下操作:

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno =10 or deptno=20; 模糊查询:

   两种方式:'_'和'%','_'代表一个未知数,'%'代表多个

//查询员工名称以S开头的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like 'S%';

//查询员工名称以S结尾的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%S';

//查询员工名称第三个字符为N的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '__N%';

//查询员工名称中含有N的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%N%';

转义字符的使用:'\'

//查询员工名称中倒数第二个字符为%的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%/%_'escape'/';

//查询员工名称总含有%的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%/%%'escape'/';

查找检索值为空的数据:'is null'

//查询奖金为null的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where comm is null;

//查询奖金非null的员工信息

SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where comm is not null;

优先级表格:

优先级   

1    算术运算

2    连接符

3    比较符

4    Is not null like not in

5    Not between

6    not

7    and

8    Or

备注:可以采用括号改变优先级   

操作sql参考附件中的sql语句

以上内容归redarmy_chen总结创建,如需转载请添加出处,如有疑问请发送到redarmy_chen@qq.com
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息