oracle 基本操作练习——简单的sql语句

一.在scott模式下,查询scott模式拥有的数据表。
select * from tab;

二.以下检索均在scott模式下
   1.查询dept和salgrade表的所有记录。
select * from dept;
select * from salgrade;

   2.查询emp表中员工编号,员工名称和职位列。
select empno,ename,job from emp;

   3.检索emp表中sal列,然后将其值调整为1.1倍。
select sal from emp;
update emp set sal = sal*1.1;

   4.查询emp表中empno,ename,job并显示为别名“员工编号”,“员工名称”,“职位”。
select empno as 员工编号, ename as 员工名称, job as 职位 from emp;

   5.显示emp表的所有职位(提示:消除重复记录)。
select distinct job from emp;

   6.显示工资不等于3000,950和800的员工的编号,名称和工资。
select empno as 员工编号, ename as 员工名称, sal as 工资 from emp where sal not in(880,1760)

   7.在emp表中查询以“s”开头的员工名称的信息。
select ename as 员工名称 from emp where ename like 'S%'

   8.查询职务为"PRESIDENT","MANAGER"和"ANALYST"的职工的编号,名称和职位。
select empno as 员工编号, ename as 员工名称, job as 职位 from emp where job in('PRESIDENT','MANAGER','ANALYST')

   9.查询emp表中员工工资在2000到3000之间的员工的编号,姓名和工资。
select empno as 员工编号, ename as 员工名称, sal as 工资 from emp where sal >= 2000 and sal <= 3000

  10.查询emp表中comm列为空的员工的信息。
select empno as 员工编号, ename as 员工名称 from emp where comm is null

  11.在emp表中,显示平均工资大于2000的部门编号和平均工资。
select deptno as 部门编号, avg(sal) as 平均工资 from emp  group by deptno having avg(sal) > 2000

  12.在emp表中,按照部门编号,员工编号升序显示员工的姓名,部门编号及员工编号。
select empno as 员工编号, ename as 员工名称, deptno as 部门编号 from emp  order by deptno asc, empno asc

  13.检索emp和dept表中,职位为“MANAGER”的员工的编号,员工名称和部门名称。
select empno as 员工编号, ename as 员工名称, dname as 部门名称 from emp,dept where emp.deptno = dept.deptno and job = 'MANAGER'

  14.查询emp表中部门名称(dname)为“RESEARCH”的员工编号,员工名称及职位。
select empno as 员工编号, ename as 员工名称, job as 职位 from emp,dept where emp.deptno=dept.deptno and dname='RESEARCH'

  15.在emp表中查询既不是最高工资也不是最低工资的员工的编号,名称及工资。
select empno as 员工编号, ename as 员工名称, sal as 工资 from emp where sal != (select max(sal) from emp) and sal != (select min(sal) from emp)


  16.查询工资大于部门编号为10的任意一个员工工资即可得其他部门的员工编号,名称及工资。
select empno as 员工编号,ename as 员工名称, sal as 工资 from emp where sal > (select min(sal) from emp where deptno = 10)

  17.查询工资大于部门编号为30的所有员工工资的员工编号,名称及工资。
select empno as 员工编号,ename as 员工名称, sal as 工资 from emp where sal > (select max(sal) from emp where deptno = 30)

  18.查询工资大于同职位的平均工资的员工编号,名称及工资。
select empno,ename,job from emp emp1 where emp1.sal > (select avg(sal) from emp emp2 where emp2.job = emp1.job)


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实验一 SQL*PLUS练习 【实验目的】 (1) 了解Oracle的工作环境和基本使用方法。 (2) 练习标准SQL的数据操作,查询命令及其查询优化。 (3) 学会使用高级SQL命令,排序、分组、自连接查询等。 (4) 学会使用SQL*PLUS命令显示报表,存储到文件等。 【实验内容】 一、 准备使用SQL*PLUS 1. 进入SQL*PLUS 2. 退SQL*PLUS 3. 显示表结构命令DESCRIBE SQL>DESCRIBE emp 使用DESCRIBE(缩写DESC)可以列指定表的基本结构,包括各字段的字段名以及类型、长度、是否非空等信息。 4. 使用SQL*PLUS显示数据库中EMP表的内容 输入下面的查询语句SQL>SELECT * FROM emp; 按下回车键执行查询 5. 执行命令文件 START或@命令将指定文件调入SQL缓冲区中,并执行文件内容。 SQL>@ 文件名(文件后缀缺省为.SQL)或 SQL>START 文件名 文件中每条SQL语句顺序装入缓冲区并执行。 二、 数据库命令——有关表、视图等的操作 1. 创建表employee 例1 定义一个人事信息管理系统中存放职工基本信息的一张表。可输入如下命令: SQL>CREATE TABLE employee (empno number(6) PRIMARY KEY, /* 职工编号 name varchar2(10) NOT NULL, /* 姓名 deptno number(2) DEFAULT 10, /* 部门号 salary number(7,2) CHECK(salarycreate table emp2 as select * from emp where 1=2; 在命令的where子句中给1=2,表示条件不可能成立,因而只能复制表结构,而不能复制任何数据到新表中去。另外,还可以复制一个表的部分列定义或部分列定义及其数据。 三、 Oracle数据库数据查询 1、单表查询 2、多表查询 四、 SQL*PLUS常用命令 表1 常用报表格式化名命令 命令 定义 Btitle 为报表的每一页设置底端标题 Column 设置列的标题和格式 Compute 让SQL*PLUS计算各种值 Remark 将某些字标记为注释 Set linesize 设置报表的行宽字符数 Set newpage 设置报表各页之间的行数 Spool 使SQL*PLUS将输写入文件中 Start 使SQL*PLUS执行一个sql文件 Ttitle 设置报表每页的头标题 Break 让SQL*PLUS进行分组操作 例3 建立一个批命令文件对查询到的数据以报表的形式输并将其保存到指定的文件中。 处理方法:利用SQL*PLUS语言工具(也可以使用其他文本编辑器)建立批命令的.SQL文件。在“SQL>”提示符下,使用EDIT命令在”E:\”中建立SCGB.SQL文件。 SCGB.SQL文件中的命令组如下: SQL>EDIT E:\ SCGB.SQL SET echo off SET pagesize 30 SET linesize 75 TTITLE’2008年4月10号’CE’公司职员基本情况登记表’R’Page:’ FORMAT 99- >SQL.PNO SKIP 1 CE’===========================’ BTITLE COL 60 ’制标单位’ TAB 3 ‘人事部’ COLUMN empno heading ‘职工|编号’ COLUMN ename format a10 heading ‘姓 名’ COLUMN job heading ‘工 种’ COLUMN sal format $99,990 heading 工 资’ COLUMN comm Like sal heading ‘奖 金’ COLUMN deptno format 9999 heading ‘部门|编号’ COLUMN hiredate heading ‘参加工作时间’ SPOOL e:\sjbb /*在E盘中建立格式报表输文件,默认属性为LST BREAK on deptno skip 1 COMPUTE sum of sal comm on deptno SELECT empno,ename,job,hiredate,sal,comm,deptno from emp ORDER BY deptno,sal; SPOOL off /*终止SPOOL功能,关闭其文件。注意,此命令不可省,否则将建立空文件。 五、 实验内容 1、以cs+学号为用户名创建用户,并授予用户创建数据对象的权限。 2、复制emp表,复制表名为emp_学号,然后将emp表中工资低于$2000 的职工插入到复制的表中。 3、对复制的emp表插入一行只包含有职工号,职工名,工资与部门号四个数据 项值的记录。 4、在复制的emp表中将雇员ALLEN提升为经理,工资增至$2500, 奖(佣 )金增加40%。 5、删除复制的emp表中工资低于500的记录行。 6、列10号部门中既不是经理,也不是秘书的职工的所有信息。 7、查找部门所在地是CHICAGO的部门的职工姓名、工资和工种。 8、统计各部门中各工种的人数、工资总和及奖金总和。 9、查找工资比其所在部门平均工资高的职工姓名、工种与工资情况。 实验3 Oracle数据库开发环境下PL/SQL编程 【实验目的】 (1)掌握 PL/SQL 的基本使用方法。 (2)在SQL*PLUS环境下运行PL/SQL简单程序。 (3)应用 PL/SQL 解决实际问题 【实验内容与步骤】 PL/SQL块中的可执行部分是由一系列语句组成的(包括对数据库进行操作SQL语句,PL/SQL语言的各种流程控制语句等)。在块中对数据库查询,增、删、改等对数据的操作是由SQL命令完成的。在PL/SQL块中,可以使用SQL的数据查询命令,数据操纵命令和事务控制命令。可使用全部SQL函数。PL/SQL中的SQL语句,可使用SQL的比较操作等运算符。但不能使用数据定义语句。 在PL/SQL块中使用SELECT语句时注意几点: (1)SELECT语句必须含有INTO子句。 (2)INTO子句后的变量个数和位置及数据类型必须和SELECT命令后的字段名表相同。 (3)INTO子句后可以是简单类型变量或组合类型变量。 (4)SELECT语句中的WHERE条件可以包含PL/SQL块中定义的变量及表达式,但变量名不要同数据库表列名相同。 (5)在未使用显式游标的情况下,使用SELECT语句必须保证只有一条记录返回,否则会产生异常情况。 [例3-1] 问题:编写一个过程,求和运算。 SET SERVEROUTPUT ON; DECLARE a number:=1; BEGIN a:=a+5; DBMS_OUTPUT.PUT_LINE('和为:'||TO_CHAR(a)); END; / 【例3-2】:使用%TYPE声明变量,输制定表中的相关信息。 DECLARE my_name student.sname%TYPE; BEGIN SELECT sname INTO my_name FROM student WHERE no=’01203001’; DBMS_OUTPUT.PUT_LINE(my_name); END; / 【例3-3】问题:编写一个过程,可以输入一个雇员名,如果该雇员的工资低于2000,就给该员工工资增加10%。 declare v_sal emp.sal%type; begin select sal into v_sal from emp where ename=spName; if v_sal :NEW.sal THEN DBMS_OUTPUT.PUT_LINE('工资减少'); ELSIF :OLD.sal < :NEW.sal THEN DBMS_OUTPUT.PUT_LINE('工资增加'); ELSE DBMS_OUTPUT.PUT_LINE('工资未作任何变动'); END IF; DBMS_OUTPUT.PUT_LINE('更新前工资 :' || :OLD.sal); DBMS_OUTPUT.PUT_LINE('更新后工资 :' || :NEW.sal); END; / --执行UPDATE查看效果 UPDATE emp SET sal = 3000 WHERE empno = '7788'; 6、需要对在表上进行DML操作的用户进行安全检查,看是否具有合适的特权。 Create table foo(a number); Create trigger biud_foo Before insert or update or delete On foo Begin If user not in (‘DONNY’) then Raise_application_error(-20001, ‘You don’t have access to modify this table.’); End if; End; / 即使SYS,SYSTEM用户也不能修改foo表。 2、 利用PL/SQL编写程序实现下列触发器 1)、编写一个数据库触发器,当任何时候某个部门从dept表中删除时,该触发器将从emp表中删除该部门的所有雇员。(要求:emp表、dept表均为复制后的表) 2)、创建一个触发器,当客户下完订单后,自动统计该订单的所有图书的价格总额。 3)、创建一个触发器,禁止客户在非工作时间(早上8:00前,晚上17:00后)下订单。 五、实验心得
### 回答1: 要将Oracle SQL语句转化为MySQL SQL语句,需要注意以下几点: 1. 日期和时间函数:MySQLOracle的日期和时间函数有些差异,需要对部分函数进行调整。例如,将Oracle的sysdate函数替换为MySQL的current_date函数,将Oracle的to_char函数替换为MySQL的date_format函数。 2. 字符串函数:Oracle和MySQL的字符串函数用法有些不同。例如,将Oracle的substr函数替换为MySQL的substring函数,将Oracle的instr函数替换为MySQL的locate函数。 3. 数据类型:某些数据类型在Oracle和MySQL中的表示方式不同,需要将其进行转换。例如,将Oracle的number类型转换为MySQL的decimal类型,将Oracle的varchar2类型转换为MySQL的varchar类型。 4. 分页查询:Oracle和MySQL分页查询的语法也有所差异。在Oracle中,可以使用rownum来进行分页,而在MySQL中,可以使用limit和offset来实现。因此,在转换查询语句时,需要将Oracle的rownum替换为MySQL的limit和offset。 5. NULL值处理:Oracle和MySQL对NULL值的处理方式也有些差异。在Oracle中,可以使用is null和is not null来判断NULL值,而在MySQL中,可以使用is null和is not null,也可以使用isnull函数。 总之,将Oracle SQL语句转化为MySQL SQL语句需要注意这些差异,并根据具体情况进行适当调整和转换。实际操作中,可以参考MySQL的官方文档和手册,以便获得更详细和准确的转换规则和示例。 ### 回答2: 将Oracle SQL语句转化为MySQL SQL语句通常需要注意以下几个方面: 1. 数据类型:Oracle和MySQL的数据类型有所不同,需要根据情况进行转换。例如,将Oracle的NUMBER数据类型转换为MySQL的INT或FLOAT类型。 2. 函数和操作符:Oracle和MySQL支持的函数和操作符有所不同,需要根据需求进行调整和替换。例如,将Oracle的TO_CHAR函数转换为MySQL的DATE_FORMAT函数。 3. 子查询和连接:Oracle和MySQL的子查询和连接语法也有所差异,需要进行适当调整。例如,将Oracle的子查询使用WITH语句转换为MySQL的内部子查询。 4. 约束和索引:Oracle和MySQL的约束和索引语法也有差异,需要进行相应修改。例如,将Oracle的UNIQUE约束转换为MySQL的UNIQUE关键字。 下面是一个具体的例子,将OracleSQL语句转换为MySQLSQL语句Oracle SQL语句: SELECT emp_name, hire_date FROM employees WHERE emp_id = 100; MySQL SQL语句: SELECT emp_name, hire_date FROM employees WHERE emp_id = 100; 这是一个简单的例子,在实际转换过程中可能会遇到更多的复杂情况,需要根据具体需求进行相应的调整和修改。同时需要注意两种数据库的差异,以免现语法错误或逻辑错误。另外,还可以通过使用一些第三方工具来自动完成SQL语句的转换,可以节省时间和精力。 ### 回答3: 要将Oracle SQL语句转化为MySQL SQL语句,需要注意一些Oracle特有的函数、关键字和语法在MySQL中可能没有或有不同的实现。下面是一些常见的转化技巧: 1. 字符串连接: Oracle使用"||"作为字符串连接符,而MySQL使用"CONCAT"函数。例如: Oracle:SELECT firstname || ' ' || lastname FROM employees; MySQL:SELECT CONCAT(firstname, ' ', lastname) FROM employees; 2. 日期格式化: Oracle使用"TO_CHAR"函数进行日期格式化,而MySQL使用"DATE_FORMAT"函数。例如: Oracle:SELECT TO_CHAR(hiredate, 'YYYY/MM/DD') FROM employees; MySQL:SELECT DATE_FORMAT(hiredate, '%Y/%m/%d') FROM employees; 3. 行号: 在Oracle中,可以使用"ROWNUM"来获取行号,而MySQL需要使用子查询和变量来实现类似的功能。例如: Oracle:SELECT * FROM employees WHERE ROWNUM <= 10; MySQL:SELECT * FROM employees WHERE id <= (SELECT id FROM employees ORDER BY id LIMIT 1 OFFSET 9); 4. 分页查询: 在Oracle使用"ROWNUM"和"FETCH FIRST"实现分页查询,而MySQL使用"LIMIT"和"OFFSET"。例如: Oracle:SELECT * FROM employees WHERE ROWNUM > 10 AND ROWNUM <= 20; MySQL:SELECT * FROM employees LIMIT 10 OFFSET 10; 5. 自增主键列: 在Oracle使用"SEQUENCE"和"TRIGGER"来生成自增主键值,而MySQL使用"AUTO_INCREMENT"关键字。例如: Oracle:CREATE SEQUENCE seq_emp_id START WITH 1 INCREMENT BY 1; CREATE TRIGGER tr_emp_id BEFORE INSERT ON employees FOR EACH ROW BEGIN SELECT seq_emp_id.nextval INTO :NEW.id FROM dual; END; MySQL:CREATE TABLE employees (id INT PRIMARY KEY AUTO_INCREMENT, firstname VARCHAR(50), lastname VARCHAR(50)); 需要注意的是,这只是一些常见的转化技巧,具体的转化还需要根据具体的SQL语句和数据库结构进行调整和适配。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值