表查询(1)
oracle表基本查询
介绍
在我们讲解的过程中我们利用scott用户存在的几张表(emp,dept)为大家演示如何使用select语句,select语句在软件编程中非常有用,希望大家好好的掌握。
emp 雇员表
clerk 普员工
salesman 销售
manager 经理
analyst 分析师
president 总裁
mgr 上级的编号
hiredate 入职时间
sal 月工资
comm 奖金
deptno 部门
dept部门表
deptno 部门编号
accounting 财务部
research 研发部
operations 业务部
loc 部门所在地点
salgrade 工资级别
grade 级别
losal 最低工资
hisal 最高工资
简单的查询语句
查看表结构
DESC emp;
查询所有列
SELECT * FROM dept;
切忌动不动就用select *
SET TIMING ON; 打开显示操作时间的开关,在下面显示查询时间。
CREATE TABLE users(userId VARCHAR2(10), uName VARCHAR2 (20), uPassw VARCHAR2(30));
INSERT INTO users VALUES('a0001', '啊啊啊啊', 'aaaaaaaaaaaaaaaaaaaaaaa');
--从自己复制,加大数据量 大概几万行就可以了 可以用来测试sql语句执行效率
INSERT INTO users (userId,UNAME,UPASSW) SELECT * FROM users;
SELECT COUNT (*) FROM users;统计行数
<!--[if !supportLineBreakNewLine]-->
<!--[endif]-->
查询指定列
SELECT ename, sal, job, deptno FROM emp;
如何取消重复行DISTINCT
SELECT DISTINCT deptno, job FROM emp;
查询SMITH所在部门,工作,薪水
SELECT deptno,job,sal FROM emp WHERE ename = 'SMITH';
注意:oracle对内容的大小写是区分的,所以ename='SMITH'和ename='smith'是不同的
<!--[if !supportLineBreakNewLine]-->
<!--[endif]-->
使用算术表达式 nvl null
问题:如何显示每个雇员的年工资?
SELECT sal*13+nvl(comm, 0)*13 "年薪" , ename, comm FROM emp;
使用列的别名
SELECT ename "姓名", sal*12 AS "年收入" FROM emp;
如何处理null值
使用nvl函数来处理
如何连接字符串(||)
SELECT ename || ' is a ' || job FROM emp;
使用where子句
问题:如何显示工资高于3000的 员工?
SELECT * FROM emp WHERE sal > 3000;
问题:如何查找1982.1.1后入职的员工?
SELECT ename,hiredate FROM emp WHERE hiredate >'1-1月-1982';
问题:如何显示工资在2000到3000的员工?
SELECT ename,sal FROM emp WHERE sal >=2000 AND sal <= 3000;
如何使用like操作符
%:表示0到多个字符 _:表示任意单个字符
问题:如何显示首字符为S的员工姓名和工资?
SELECT ename,sal FROM emp WHERE ename like 'S%';
如何显示第三个字符为大写O的所有员工的姓名和工资?
SELECT ename,sal FROM emp WHERE ename like '__O%';
在where条件中使用in
问题:如何显示empno为7844, 7839,123,456 的雇员情况?
SELECT * FROM emp WHERE empno in (7844, 7839,123,456);
使用is null的操作符
问题:如何显示没有上级的雇员的情况?
错误写法:select * from emp where mgr = '';
正确写法:SELECT * FROM emp WHERE mgr is null;
相关推荐
Oracle 11g SQL和PL SQL从入门到精通 pdf格式电子书 下载(一) http://download.csdn.net/source/3268267 Oracle 11g SQL和PL SQL从入门到精通 pdf格式电子书 下载(二) ...
Oracle+11g+从入门到精通part1(共3卷)
第二个压缩包
Oracle.11g.从入门到精通.part1
Oracle 11g 从入门到精通,很好的oracle入门教程。
Oracle+11g+从入门到精通.part3.rar
这个压缩包文件包含了"Oracle11g从入门到精通"的三个部分,可能是系列教程或者书籍的电子版,旨在帮助初学者和有一定基础的学习者全面理解并掌握Oracle11g的相关知识。 在Oracle11g的学习过程中,首先你需要了解...
适合初学者入门,也适合有经验者做参考书,绝对值得一看
Oracle11g从入门到精通.part4
Oracle.11g.从入门到精通.part2
第1章 在windows 平台上安装oracle database 11g 第2章 配置网络服务名 第3章 使用sql database 第4章 使用sql*plus 第二部分 sql 第5章 sql和pl/sql综述 第6章 简单查询 第7章 sql单行函数 第8章 ...
Oracle 11g 从入门到精通.part2,很好的入门教程
Oracle+11g+从入门到精通.part1 共两卷
Oracle 11g 从入门到精通part3(共3卷)
学习oracle sql pl/sql入门的很不错的一本书。
对于新手学习Oracle很不错的一本书,
学习ORACLE SQL PL/SQL入门很不错的一本书。
Oracle 11g 从入门到精通part2(共3卷)