首页 > 代码库 > 六、表查询一
六、表查询一
通过scott用户下的表来演示如何使用select语句,接下来对emp、dept、salgrade表结构进行解说。 emp 雇员表字段名称 数据类型 是否为空 备注-------- ----------- -------- --------EMPNO NUMBER(4) 员工编号 ENAME VARCHAR2(10) Y 员工名称 JOB VARCHAR2(9) Y 职位 MGR NUMBER(4) Y 上级的编号 HIREDATE DATE Y 入职日期 SAL NUMBER(7,2) Y 月工资 COMM NUMBER(7,2) Y 奖金 DEPTNO NUMBER(2) Y 所属部门-------------------------------------------job字段:clerk 普员工salesman 销售manager 经理analyst 分析师president 总裁 dept 部门表字段名称 数据类型 是否为空 备注-------- ----------- -------- --------DEPTNO NUMBER(2) 部门编号 DNAME VARCHAR2(14) Y 部门名称 LOC VARCHAR2(13) Y 部门所在地点-------------------------------------------DNAME字段:accounting 财务部research 研发部operations 业务部 salgrade 工资级别表字段名称 数据类型 是否为空 备注-------- --------- -------- --------GRADE NUMBER Y 级别 LOSAL NUMBER Y 最低工资 HISAL NUMBER Y 最高工资 1、查看表结构desc emp; 2、查询所有列select * from dept;备注:切忌动不动就用select *,使用*效率比较低,特别在大表中要注意。 3、set timing on/off;打开显示操作时间的开关,在底部显示操作时间。eg、sql> insert into tb_stu values(‘0001‘, ‘zhangsan‘, 24);1 row insertedexecuted in 0.015 seconds 4、insert into...select...表复制语句语法:insert into table2(field1,field2,...) select value1,value2,... from table1--创建tb_dept表create table tb_dept( deptno number(4) not null, dname varchar2(14), loc varchar2(13))--添加主键约束alter table tb_dept add constraint tb_dept primary key (deptno);--insert into...select...用法insert into tb_dept (deptno, dname, loc) select a.deptno, a.dname, a.loc from dept a; 5、统计select count (*) from emp; 6、查询指定列select ename, sal, job, deptno from emp; 7、如何取消重复行distinctselect distinct deptno, job from emp; 8、查询smith所在部门,工作,薪水select deptno, job, sal from emp where ename = ‘smith‘;注意:oracle对内容的大小写是敏感的,所以ename=‘smith‘和ename=‘smith‘是不同的 9、nvl函数格式为:nvl(string1, replace_with) 功能:如果string1为null,则nvl函数返回replace_with的值,否则返回string1的值。 注意事项:string1和replace_with必须为同一数据类型,除非显示的使用to_char函数。 eg、如何显示每个雇员的年工资?select sal*13+nvl(comm, 0)*13 "年薪" , ename, comm from emp; 10、使用列的别名select ename "姓名", sal*12 as "年收入" from emp; 11、如何处理null值使用nvl函数来处理 12、如何连接字符串(||)select ename || ‘ is a ‘ || job from emp; 13、使用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; 14、如何使用like操作符%:表示0到多个字符 _:表示任意单个字符问题:如何显示首字符为s的员工姓名和工资?select ename,sal from emp where ename like ‘s%‘;如何显示第三个字符为大写o的所有员工的姓名和工资?select ename,sal from emp where ename like ‘__o%‘; 15、在where条件中使用in问题:如何显示empno为7844,7839,123,456的雇员情况?select * from emp where empno in (7844, 7839, 123, 456); 16、使用is null的操作符问题:如何显示没有上级的雇员的情况?错误写法:select * from emp where mgr = ‘‘;正确写法:select * from emp where mgr is null;
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。