KEMBAR78
SQL Queries and Table Structures | PDF | Sql | Database Index
0% found this document useful (0 votes)
260 views17 pages

SQL Queries and Table Structures

The question asks which SQL statement shows the department ID, minimum salary, and maximum salary paid in that department, only if the minimum salary is less than 5000 and the maximum salary is more than 15000, based on data in the EMPLOYEES table. The correct statement is b, which selects the requested columns, groups the results by department ID, and applies the filters to the aggregate minimum and maximum salary values.
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOC, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
260 views17 pages

SQL Queries and Table Structures

The question asks which SQL statement shows the department ID, minimum salary, and maximum salary paid in that department, only if the minimum salary is less than 5000 and the maximum salary is more than 15000, based on data in the EMPLOYEES table. The correct statement is b, which selects the requested columns, groups the results by department ID, and applies the filters to the aggregate minimum and maximum salary values.
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOC, PDF, TXT or read online on Scribd
You are on page 1/ 17

Examine the description of the EMPLOYEES table.

EMP_ID NUMBER(4) NOT NULL LAST_NAME VARCHAR2(30) NOT NULL FIRST_NAME VARCHAR2(30) DEPT_ID NUMBER(2) JOB_CAT VARCHAR2(30) SALARY NUMBER(8,2) Which statement shows the department ID, minimum salary, and maximum salary paid in that department, only of the minimum salary is less then 5000 and the maximum salary is more than 15000? a. SELECT dept_id, MIN(salary), MAX(salary) FROM employees WHERE MIN(salary) < 5000 AND MAX(salary) > 15000; b. SELECT dept_id, MIN(salary), MAX(salary) FROM employees WHERE MIN(salary) < 5000 AND MAX(salary) > 15000 GROUP BY dept_id; c. SELECT dept_id, MIN(salary), MAX(salary) FROM employees HAVING MIN(salary) < 5000 AND MAX(salary) > 15000; d. SELECT dept_id, MIN(salary), MAX(salary) FROM employees GROUP BY dept_id HAVING MIN(salary) < 5000 AND MAX(salary) < 15000; e. SELECT dept_id, MIN(salary), MAX(salary) FROM employees GROUP BY dept_id, salary HAVING MIN(salary) < 5000 AND MAX(salary) > 15000;
2. You added a PHONE_NUMBER column of NUMBER data type to an

a. b. c. d. e.

existing EMPLOYEES tablThe EMPLOYEES table already contains records of 100 employees. Now, you want to enter the phone numbers of each of the 100 employees into the table. Some of the employees may not have a phone number availablWhich data manipulation operation do you perform? MERGE INSERT UPDATE ADD ENTER
Page 1 of 17

f. 3.

You cannot enter the phone numbers for the existing employee records. You need to create a view EMP_VU. The view should allow the users to manipulate the records of only the employees that are working for departments 10 or 20. Which SQL statement would you use to create the view EMP_VU? CREATE VIEW emp_vu AS SELECT * FROM employees WHERE department_id IN (10,20); CREATE VIEW emp_vu AS SELECT * FROM employees WHERE department_id IN (10,20) WITH READ ONLY; CREATE VIEW emp_vu AS SELECT * FROM employees WHERE department_id IN (10,20) WITH CHECK OPTION; CREATE FORCE VIEW emp_vu AS SELECT * FROM employees WHERE department_id IN (10,20); CREATE FORCE VIEW emp_vu AS SELECT * FROM employees WHERE department_id IN (10,20) NO UPDATE;

a.

b.

c.

d.

Page 2 of 17

4. Examine the data from the ORDERS and CUSTOMERS tables. ORDERS ORD_ID 100 101 102 103 104 105 106 107 109 CUSTOMERS CUST_ID 10 15 20 25 30 35 40 ORD_DATE 12-JAN-2000 09-MAR-2000 09-MAR-2000 15-MAR-2000 25-JUN-2000 18-JUL-2000 18-JUL-2000 21-JUL-2000 04-AUG-2000 CUST_ID 15 40 35 15 15 20 35 20 10 ORD_TOTAL 10000 8000 12500 12000 6000 5000 7000 6500 8000

CUST_NAME Smith Bob Martin Mary Rina Smith Lind

CITY Los Angeles Sanfranciso Chicago New York Chicago New York New York

Evaluate the SQL statement: SELECT * FROM orders WHERE cust_id = (SELECT cust_id FROM customers WHERE cust_name = 'Smith'); What is the result when the query is executed? a. ORD_ID ORD_DATE CUST_ID
102 106 108 09-MAR-2000 18-JUL-2000 04-AUG-2000 35 35 10

ORD_TOTAL
12500 7000 8000

b. ORD_ID ORD_DATE CUST_ID ORD_TOTAL


Page 3 of 17

102 106

09-MAR-2000 18-JUL-2000

35 35

12500 7000

c. ORD_ID
108

ORD_DATE
04-AUG-2000

CUST_ID
10

ORD_TOTAL
8000

d. The query fails because the subquery returns more than one row. e. The query fails because the outer query and the inner query are using different tables. 5. a. b. c. d. e. f. Which is an SQL*Plus command? INSERT UPDATE SELECT DESCRIBE DELETE RENAME

Page 4 of 17

You need to produce a report for mailing labels for all customers. The mailing label must have only the customer name and address. The CUSTOMERS table has these columns: CUST_ID NUMBER(4) NOT NULL CUST_NAME VARCHAR2(100) CUST_ADDRESS VARCHAR2(150) CUST_PHONE VARCHAR2(20) Which SELECT statement accomplishes this task? a. b. c. d. e. SELECT* FROM customers; SELECT name, address FROM customers; SELECT id, name, address, phone FROM customers; SELECT cust_name, cust_address FROM customers; SELECT cust_id, cust_name, cust_address, cust_phone FROM customers;

6.

Examine the structure of the EMPLOYEES table. EMPLOYEE_ID NUMBER Primary Key FIRST_NAME VARCHAR2(25) LAST_NAME VARCHAR2(25) Which three statements inserts a row into the table? (Choose three.)
7.

a.

INSERT INTO employees VALUES ( NULL, John,Smith); b. INSERT INTO employees( first_name, last_name) VALUES(John,Smith); c. INSERT INTO employees VALUES (1000,John,NULL); d. INSERT INTO employees(first_name,last_name, employee_id) VALUES ( 1000, John,Smith); e. INSERT INTO employees (employee_id) VALUES (1000); f. INSERT INTO employees (employee_id, first_name, last_name) VALUES ( 1000, John,);

Page 5 of 17

8. You need to modify the STUDENTS table to add a primary key on the STUDENT_ID column. The table is currently empty. Which statement accomplishes this task? a. ALTER TABLE students ADD PRIMARY KEY student_id; b. ALTER TABLE students ADD CONSTRAINT PRIMARY KEY (student_id); c. ALTER TABLE students ADD CONSTRAINT stud_id_pk PRIMARY KEY student_id; d. ALTER TABLE students ADD CONSTRAINT stud_id_pk PRIMARY KEY (student_id); e. ALTER TABLE students MODIFY CONSTRAINT stud_id_pk PRIMARY KEY (student_id); 9. a. b. c. d. For which two constraints does the Oracle Server implicitly create a unique index? (Choose two.) NOT NULL PRIMARY KEY FOREIGN KEY CHECK UNIQUE

10. In a SELECT statement that includes a WHERE clause, where is the GROUP BYclause placed in the SELECT statement? a. Immediately after the SELECT clause b. Before the WHERE clause c. Before the FROM clause d. After the ORDER BY clause e. After the WHERE clause The CUSTOMERS table has these columns. CUSTOMER_ID NUMBER(4) NOT NULL CUSTOMER_NAME VARCHAR2(100) NOT NULL STREET_ADDRESS VARCHAR2(150) CITY_ADDRESS VARCHAR2(50) STATE_ADDRESS VARCHAR2(50) PROVINCE_ADDRESS VARCHAR2(50) COUNTRY_ADDRESS VARCHAR2(50) POSTAL_CODE VARCHAR2(12) CUSTOMER_PHONE VARCHAR2(20)
11.

Which statement finds the rows in the CUSTOMERS table that do not have a postal code? a. SELECT customer_id, customer_name
Page 6 of 17

b.

c.

d.

e.

FROM customers WHERE postal_code CONTAINS NULL; SELECT customer_id, customer_name FROM customers WHERE postal_code = '________'; SELECT customer_id, customer_name FROM customers WHERE postal_code IS NULL; SELECT customer_id, customer_name FROM customers WHERE postal code IS NVL; SELECT customer_id, customer_name FROM customers WHERE postal_code = NULL;

Examine the structure of the EMPLOYEES table. EMPLOYEE_ID NUMBER Primary Key FIRST_NAME VARCHAR2(25) LAST_NAME VARCHAR2(25) DEPARTMENT_ID NUMBER SALARY NUMBER What is the correct syntax for an inline view? a. SELECT a.last_name, a.salary, a.department_id, b.maxsal FROM employees a, (SELECT department_id, max(salary)maxsal FROM employees GROUP BY department_id) b WHERE a.department_id = b.department_id AND a.salary < b.maxsal; b. SELECT a.last name, a.salary, a.department_id FROM employees a WHERE a.department_id IN (SELECT department_id FROM employees b GROUP BY department_id having salary = (SELECT max(salary) from employees)) c. SELECT a.last_name, a.salary, a.department_id FROM employees a
12.
Page 7 of 17

WHERE a.salary = (SELECT max(salary) FROM employees b WHERE a.department_id = b.department_id); d. SELECT a.last_name, a.salary, a.department_id FROM employees a WHERE (a.department_id, a.salary) IN (SELECT department_id, a.salary) IN (SELECT department_id max(salary) FROM employees b GROUP BY department_id ORDER BY department_id); 13. You need to calculate the total of all salaries in the accounting department. Which group function should you use? a. MAX b. MIN c. SUM d. COUNT e. TOTAL f. LARGEST 14. a. b. c. d. Which constraint can be defines only at the column level? UNIQUE NOT NULL CHECK PRIMARY KEY FOREIGN KEY

15. Examine the data in the EMPLOYEES and DEPARTMENTS tables. EMPLOYEES
LAST_NAME Getz Davis King Davis Kochhar DEPARTMENT_ID 10 20 20 30 10 SALARY 3000 1500 2200 5000 5000

DEPARTMENTS
DEPARTMENT_ID 10 20 30 40 DEPARTMENT_NAME Sales Marketing Accounts Administration
Page 8 of 17

You want to retrieve all employees, whether or not they have matching departments in the departments tablWhich query would you use? a. SELECT last_name, department_name FROM employees, departments(+); b. SELECT last_name, departme nt_name FROM employees JOIN departments (+); SELECT last_name, department_name FROM employees(+) e JOIN departments d ON (e.department_id = d.department_id); c. SELECT last_name, department_name FROM employees e d. RIGHT OUTER JOIN departments d ON (e.department_id = d.department_id); SELECT last_name, department_name FROM employees(+), departments ON (e.department_id = d.department_id); e. SELECT last_name, department_name FROM employees e LEFT OUTER JOIN departments d ON (e.department_id = d.department_id); Examine the data in the EMPLOYEES table:
DEPARTMENT_ID 10 20 20 30 10 SALARY 3000 1500 2200 5000 5000

16.

LAST_NAME Getz Davis King Davis Kochhar

Which three subqueries work? (Choose three.) a. SELECT * FROM employees where salary > (SELECT MIN(salary) FROM employees GROUP BY department.id); b. SELECT * FROM employees WHERE salary = (SELECT AVG(salary) FROM employees GROUP BY department_id); c. SELECT distinct department_id FROM employees Where salary > ANY (SELECT AVG(salary) FROM employees GROUP BY department_id); d. SELECT department_id FROM employees
Page 9 of 17

WHERE SALARY > ALL (SELECT AVG(salary) FROM employees GROUP BY department_id); e. SELECT last_name FROM employees Where salary > ANY (SELECT MAX(salary) FROM employees GROUP BY department_id); f. SELECT department_id FROM employees WHERE salary > ALL (SELECT AVG(salary) FROM employees GROUP BY AVG(SALARY)); 17. You created a view called EMP_DEPT_VU that contains three columns from the EMPLOYEES and DEPARTMENTS tables.EMPLOYEE_ID, EMPLOYEE_NAME AND DEPARTMENT_NAMThe DEPARTMENT_ID column of the EMPLOYEES table is the foreign key to the primary key DEPARTMENT_ID column of the DEPARTMENTS table. You want to modify the view by adding a fourth column, MANAGER_ID of NUMBER data type from the EMPLOYEES tables. How can you accomplish this task? a. ALTER VIEW emp_dept_vu (ADD manager_id NUMBER); MODIFY VIEW emp_dept_vu (ADD manager_id NUMBER); b. ALTER VIEW emp_dept_vu AS SELECT employee_id, employee_name, department_name, manager_id FROM employee e, departments d WHERE e.department_id = d.department_id; c. MODIFY VIEW emp_dept_vu AS SELECT employee_id, employee_name, department_name, manager_id FROM employees e, departments d WHERE e.department_id = d.department_id; d. CREATE OR REPLACE VIEW emp_dept_vu AS SELECT employee_id, employee_name, department_name, manager_id FROM employees e, departments d WHERE e.department_id = d.department_id; You must remove the existing view first, and then run the CREATE VIEW command with a new column list to modify a view.

Page 10 of 17

18. Examine the structure of the EMPLOYEES and NEW_EMPLOYEES tables: EMPLOYEES EMPLOYEE_ID NUMBER Primary Key FIRST_NAME VARCHARD2(25) LAST_NAME VARCHARD2(25) HIRE_DATE DATE NEW EMPLOYEES EMPLOYEE_ID NUMBER Primary Key NAME VARCHAR2(60) Which UPDATE statement is valid? a. UPDATE new_employees SET name = (Select last_name|| first_name FROM employees Where employee_id =180) WHERE employee_id =180; b. UPDATE new_employees SET name = (SELECT last_name||first_name FROM employees) WHERE employee_id =180; c. UPDATE new_employees SET name = (SELECT last_name|| first_name FROM employees WHERE employee_id =180) WHERE employee_id =(SELECT employee_id FROM new employees); d. UPDATE new_employees SET name = (SELECT last name|| first_name FROM employees WHERE employee_id= (SELECT employee_id FROM new_employees)) WHERE employee_id =180;
19.

a. b. c.

What is necessary for your query on an existing view to execute successfully? The underlying tables must have data. You need SELECT privileges on the view. The underlying tables must be in the same schema.
Page 11 of 17

d.
20.

You need SELECT privileges only on the underlying tables.

Which two statements are true regarding the ORDER BY clause? (Choose two.) a. The sort is in ascending by order by default. The sort is in descending order by default. b. The ORDER BY clause must precede the WHERE claus The ORDER BY clause is executed on the client side. c. The ORDER BY clause comes last in the SELECT statement. d. The ORDER BY clause is executed first in the query execution. e. 21. Which two statements about sequences are true? (Choose two.) a. You use a NEXTVAL pseudo column to look at the next possible value that would be generated from a sequence, without actually retrieving the value. b. You use a CURRVAL pseudo column to look at the current value just generated from a sequence, without affecting the further values to be generated from the sequence. c. You use a NEXTVAL pseudo column to obtain the next possible value from a sequence by actually retrieving the value from the sequence. d. You use a CURRVAL pseudo column to generate a value from a sequence that would be used for a specified database column. e. If a sequence starting from a value 100 and incremented by 1 is used by more then one application, then all of these applications could have a value of 105 assigned to their column whose value is being generated by the sequence. f. You use REUSE clause when creating a sequence to restart the sequence once it generates the maximum value defined for the sequence. 22. A subquery can be used to _________. a. Create groups of data b. Sort data in a specific order c. Convert data to a different format d. Retrieve data based on an unknown condition Evaluate the SQL statement DROP TABLE DEPT;
23.

Which four statements are true of the SQL statement? (Choose four.) You cannot roll back this statement. a. All pending transactions are committed. b. All views based on the DEPT table are deleted. c. All indexes based on the DEPT table are dropped. d. All data in the table is deleted, and the table structure is also deleted. e. All data in the table is deleted, but the structure of the table is retaine
Page 12 of 17

f.

All synonyms based on the DEPT table are deleted.

24. Which two statements about views are true? (Choose two.) a. A view can be created as read only. b. A view can be created as a join on two or more tables. c. A view cannot have an ORDER BY clause in the SELECT statement. d. A view cannot be created with a GROUP BY clause in the SELECT statement. e. A view must have aliases defined for the column names in the SELECT statement. 25. Evaluate the SQL statement: SELECT ROUND(TRUNC(MOD(1600,10),-1),2) FROM dual; What will be displayed? a. 0 b. 1 c. 0.00 d. An error statement Examine the data in the EMPLOYEES and EMP_HIST tables. EMPLOYEES
26.

EMPLOYEE_ID 101 102 103 104 105 106 108 110 120

NAME Smith Martin Chris John Diana Smith Jennifer Bob Ravi

DEPT_ID 20 10 20 30 30 40 30 40 20

MGR_ID 120 105 120 108 108 110 110 EX_DIR 110

JOB_ID SA_REP CLERK IT_ADMIN HR_CLERK IT_ADMIN AD_ASST HR_DIR 8000 SA_DIR

SALARY 4000 2500 4200 2500 5000 3000 6500 6500

EMP_HIST
EMPLOYEE_ID 101 103 104 106 108 NAME Smith Chris John Smith Jennifer JOB_ID SA_CLERK IT_CLERK HR_CLERK AD_ASST HR_MGR SALARY 2000 2200 2000 3000 4500

The EMP_HIST table is updated at the end of every year. The employee ID, name, job ID, and salary of each existing employee are modified with the latest datNew employee details are added to the table.
Page 13 of 17

Which statement accomplishes this task? a. UPDATE emp_hist SET employee_id, name, job_id, salary = (SELECT employee_id, name, job_id, salary FROM employees) WHERE employee_id IN (SELECT employee_id FROM employees); MERGE INTO emp_hist eh b. USING employees e ON (eh.employee_id = e.employee_id) WHEN MATCHED THEN UPDATE SET eh.name = e.name, eh.job_id = e.job_id, eh.salary = e.salary WHEN NOT MATCHED THEN INSERT VALUES (e.employee id, e.name, e.job id, e.salary); MERGE INTO emp_hist eh c. USING employees e ON (eh.employee_id = e.employee_id) WHEN MATCHED THEN UPDATE emp hist SET eh.name = e.name, eh.job_id = e.job_id, eh.salary = e.salary WHEN NOT MATCHED THEN INSERT INTO emp_hist VALUES (e.employee_id, e.name, e.job_id, e.salary); MERGE INTO emp_hist eh d. USING employees e WHEN MATCHED THEN UPDATE emp_hist SET eh.name = e.name, eh.job_id = e.job_id, eh.salary = e.salary WHEN NOT MATCHED THEN INSERT INTO emp_hist VALUES (e.employee_id, e.name, e.job_id, e.salary); The CUSTOMERS table has these columns. CUSTOMER_ID NUMBER(4) NOT NULL CUSTOMER_NAME VARCHAR2(100) NOT NULL STREET_ADDRESS VARCHAR2(150) CITY_ADDRESS VARCHAR2(50) STATE_ADDRESS VARCHAR2(50) PROVINCE_ADDRESS VARCHAR2(50) COUNTRY_ADDRESS VARCHAR2(50) POSTAL_CODE VARCHAR2(12) CUSTOMER_PHONE VARCHAR2(20)
27.

The CUSTOMER_ID column is the primary key for the table. Which two statements find the number of customers? (Choose two.)
Page 14 of 17

a. b. c. d. e.
f.
28.

SELECT TOTAL(*) FROM customers; SELECT COUNT(*) FROM customers; SELECT TOTAL(customer_id) FROM customers; SELECT COUNT(customer_id) FROM customers; SELECT COUNT(customers) FROM customers; SELECT TOTAL(customer_name) FROM customers; Which operator can be used with a multiple-row subquery? = LIKE BETWEEN NOT IN IS <> Which statement creates a new user? CREATE USER susan; CREATE OR REPLACE USER susan; CREATE NEW USER susan DEFAULT; CREATE USER susan IDENTIFIED BY blue; CREATE NEW USER susan IDENTIFIED by blue; CREATE OR REPLACE USER susan IDENTIFIED BY blue;

a. b. c. d. e.

29.

a. b. c. d. e. f.

The DBA issues this SQL command: CREATE USER scott IDENTIFIES by tiger; What privileges does the user Scott have at this point? a. No privileges. b. Only the SELECT privilege. c. Only the CONNECT privilege. d. All the privileges of a default user.
30.

31. Which syntax turns an existing constraint on? a. ALTER TABLE table_name ENABLE constraint_name; b. ALTER TABLE table_name STATUS = ENABLE CONSTRAINT constraint_name; c. ALTER TABLE table_name
Page 15 of 17

ENABLE CONSTRAINT constraint_name; d. ALTER TABLE table_name STATUS ENABLE CONSTRAINT constraint_name; e. ALTER TABLE table_name TURN ON CONSTRAINT constraint_name; f. ALTER TABLE table_name TURN ON CONSTRAINT constraint_name; You want to display the titles of books that meet these criteria: 1. Purchased before January 21, 2001 2. Price is less then $500 or greater than $900 You want to sort the results by their data of purchase, starting with the most recently bought book. Which statement should you use? a. SELECT book_title FROM books WHERE price between 500 and 900 AND purchase_date < 21-JAN-2001 ORDER BY purchase_date; b. SELECT book_title FROM books WHERE price IN (500,900) AND purchase_date < 21-JAN-2001 ORDER BY purchase date ASC; c. SELECT book_title FROM books WHERE price < 500 or > 900 AND purchase_date < 21-JAN-2001 ORDER BY purchase date DESC; d. SELECT book_title FROM books WHERE (price < 500 OR price > 900) AND purchase_date < 21-JAN-2001 ORDER BY purchase date DESC;
32.

Evaluate these two SQL statements. SELECT last_name, salary, hire_date FROM EMPLOYEES ORDER BY salary DESC; SELECT last_name, salary, hire_date FROM EMPLOYEES ORDER BY 2 DESC; What is true about them? a. The two statements produce identical results. The second statement returns a syntax error. b. There is no need to specify DESC because the results are sorted in descending order by default. c. The two statements can be made to produce identical results by adding a
33.
Page 16 of 17

column alias for the salary column in the second SQL statement. 34. Which three statements about subqueries are true? (Choose three.) a. A single row subquery can retrieve only one column and one row. b. A single row subquery can retrieve only one row but many columns. c. A multiple row subquery can retrieve multiple rows and multiple columns d. A multiple row subquery can be compared by using the > operator. e. A single row subquery can use the IN operator. f. A multiple row subquery can use the = operator. 35. a. b. c. d. e. Which clause should you use to exclude group results? WHERE HAVING RESTRICT GROUP BY ORDER BY

Page 17 of 17

You might also like