数据类型: 数据是信息数字表现形式,信息的加工处理是以大量的结构化数据为载体进行的,数据 库管理系统的核心是数据库,数据库的主要对象是表,表是结构化数据存储的地方. Oracle系统也提供了大量的数据类型主要包括两大类: 用户自定义的数据类型 内置的数据类型 A、字符型 字符数据类型可以用于声明包含了多个字母数字数据的字段。 固定长度的字符类型 char:用于存储固定长度的字符,一旦声明长度固定(不论你存储的实际大小,但是大小绝对不能大于声明的长度)长度不足时,采用空格补充。1B的默认大小,最大尺寸为2000B。 Nchar与char的解析是一样的不过,ncarh存储的是Unicode字符数据。 可变长度的字符类型 varchar与char类似,但是它是用于存储可变的字符串,而char用于存储固定的字符串。 Nvarchar与varchar解析是一样的,不过nvarchar用于存储的数据位双字节的数据。 日期型 date 短日期格式(1990-10-10) Timestamp长日期格式(1990-10-10 10:10:10) 数字型 Number(2),代表:声明一个2位数字的整数。 Number(3,2)代表:声明为3数字位,并且小数后有2位。 文本型-lob数据类型 Blob:可以存储图像,音频文件及视频等文件。 Clob:字符格式的大型对象,oracle数据unicode格式的编码 Bfile:用于存储二进制格式的文件。 rowid 伪劣类型:用于在oracle内部保存表中的每条记录的物理地址。 四、SQL查询介绍 SQL是structured Query Language(结构化查询语言)的缩写。可以使用sql语句建立 或删除数据库的对象,插入,修改和更新数据库中的数据,并且可以对数据库执行各种日常 管理的操作。它是所有关系数据库管理系统的标准语言.换句话说使用sql可以对所有的 关系数据库进行操作。 1、SQl介绍 SQL按照功能分类: 数据库定义语句 DDL(Data Definition Language):用于创建、修改、删除数据库对象。 数据库操作语句 DML(Data Manipulation Language)用于:查询,添加修改或删除存在数据库对象中的数据。 数据库控制语句DCL DCL(Data Control Language)用于控制访问数据库中特定对象的用户、grant revoke Oracle系统中经过对Sql语言扩展被称为PL/SQL语言。 2、基本查询 SELECT *|{[DISTINCT] column|expression [alias],...} FROM table; 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;//查询去掉重复行的员工部门编号 3、条件查询 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。 //查询部门号大于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 sal3000; 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 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 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'\'; //查询奖金为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 备注:可以采用括号改变优先级