Locking prevents destructive interaction between concurrent transactions. Locks held until Commit or Rollback. Types of locking are:
Further, there are two locking methods:
- Exclusive: Locks out other users
- Share: Allows other users to access
Analytical Function :
Analytic functions calculate an aggregate value based on a group of rows. Analytical functions are
aggregate functions, but we can apply the aggregate function on the table or the selected area in the where clause. The analytical function is an aggregate function but offers additional stuff.
DENSE_RANK( ) OVER([ query_partition_clause ] order_by_clause)
Different Types of Join :
Inner Join: Inner Join return only matching record.
Left Outer Join: Inner Join+fetch any additional records from the left table which is not present
in the right table.
Right Outer Join: Inner Join+fetch any additional records from the right table which is not present
in the left table.
Full Outer Join: Inner Join
+Fetch any additional records from the left table which is not present in the right table.
+Fetch any additional records from the right table which is not present in the left table.
Cross Join: Every record from the first table will try to match every record from the second table.
Natural Join: Natural join is not recommended. There is no need to mention the joining condition. It will
automatically calculate the joining column name if it is the same column.
If the same column name exists within two tables, then it will return Inner Join, and if the same.
If the column does not exist within two tables, it will return Cross Join.
Self Join: Usually a join happens between two tables which are based on certain conditions when instead of two different tables, we use the same table for joining which is referred to as a self join.
Index In Oracle :
Indexes are database objects which can be created on a table or table cluster and, if applied correctly, can
speed up data retrieval in certain cases. Indexes are database object which actually resides in memory.
The index is useful when we use 5%-10% of the data.
Query Explain: EXPLAIN PLAN FOR (Add This before select statement).
SELECT * FROM TABLE (DBMS_XPLAN.DISPLAY);
Analyze Index: analyze index idx_ind(index name) validate structure
select height, name,blks,br_blks from index_status;
Types of indexes:
1. B-Tree Index
2.Bitmap Index
3. Function-Based Index
4. Reverse key Index
5. Composite Index
1.BTree Index: Default Index. B-Tree shorts, for balanced trees, are the most common type of
database index. If we don't specify any keyword while creating an index, it will go ahead and
create a B-tree Index. By default, Oracle creates B-Tree Index. B-tree index scan types are-
Range Scan, Unique Scan, Full Scan, Full Scan, Fast full scan.
2. Bitmap Index
Oracle uses two methods to access the data when we submit a query. One is a Table scan, and
another is an Index scan. If Index is not there, then oracle uses a Table scan. Table scan searches each
and every record of the table.
Two types of Index scans -Index full scan and Index fast full scan. If all the columns that are part of
our select query should be part of our composite index, and if we use order by clause, then we should
use the column as taken in my composite index. Also, it will be a fas1.t full scan.
Different between B-Tree and BITMAP Index:
1. BTREE Store data in tree format. BITMAP indexes are stored as dimensional arrays.
2. BTREE Index is created on high cardinality columns. BITMAP Index is created on
low cardinality (low number of distinct values in a column. Ex-Male, Female ).
3. we should create a BITMAP index only if the data is being modified by a single proc
BTREE Reverse key Index :
Does creating primary key constraints always create an index automatically?
When we create a constraint oracle will create an index if the column is not indexed already if the column is already indexed then oracle will not create a new index.
Will dropping constraints will drop the underlying index?
Yes, but not always. Whenever we are dropping a constraint the associated index will get automatically dropped provided that index was created as part of the constraint creation otherwise the index will not drop.
Can a primary key create a NONUNIQUE index?
Normally when we create a primary key constraint oracle will automatically create a unique index. But in some scenarios, a primary key will create a non-unique index. By using
DEFERRABLE NOVALIDATE keyword we can create a primary key that will create a non-unique index.
Different between Constraints & Index :
1. Unique Constraints are for data integrity, whereas Unique Index is for performance improvement.
Table Partition:
Partition subdivided our table into smaller pieces. Any table bigger than 2GB may be a possible contender for partitioning. So the first thing that partition gave us was an improvement in performance. The second thing is data manageability.
Local Index: If we create an index that is not part of the partitioning key, we should consider a local index.
Global Index: If we create an index which is part of the partitioning key, then we should consider a global index.
List Partition:
Range Partition:
Hash Partition: If we want to distribute data equally among all the nodes, then we can create a hash partition.
Composite Partition :
Advantages of Partition :
Performance:
1. Partition pruning
2. Partition wise join
Manageability:
1. Divide and conquer approach
2. Faster backup and restore
3. Low storage usage
Example:
CREATE TABLE TRANSACTION_DEMO (TRANSACTION_ID NUMBER,TRANSACTION_TYPE VARCHAR2(30),AMOUNT NUMBER, TRANSACTION_DATE DATE);
CREATE UNIQUE INDEX IDX_TRAN_ID ON TRANSACTION_DEMO(TRANSACTION_ID);
SELECT * FROM TRANSACTION_DEMO;
INSERT INTO TRANSACTION_DEMO
SELECT ROWNUM,'CREDIT',FLOOR(DBMS_RANDOM.VALUE(90,9000)),TRUNC(SYSDATE) FROM DUAL CONNECT BY LEVEL <=1000000;
SELECT SEGMENT_NAME,BLOCKS,BYTES/1024/1024 AS MB FROM USER_SEGMENTS WHERE SEGMENT_NAME='TRANSACTION_DEMO';
ANALYZE INDEX IDX_TRAN_ID VALIDATE STRUCTURE;
SELECT * FROM INDEX_STATS;
Dual Table: When the Oracle database is installed, then it will automatically create a DUAL table. It is
created on the sys user and available for all users. The column of this table is DUMMY value of this column is
X and Data Type is Varchar2(1);
Different between Delete, Truncate and Drop:
Delete: Can delete partial data.DML Operation. Recover using rollback.No impact on dependent objects.
Deleted data is temporary store in the redo log.
Truncate: Remove the entire data.DDL Operation. Data lost forever.No impact dependent objects.
Drop: Removes the object.DDL Operation. Data can be recovered (Flashback option).
Dependent objects will have to be created.
Different between Procedure and function: Functions are normally used for computations, while
Procedures usually execute business logic. The procedure can't be called from the SQL statement but
The function can be called from an SQL statement.
Can we use OUT and INOUT parameters in the function?
Yes, we can use OUT and INOUT parameters in a function. But there is a restriction. This type of
function we can't use within select statements. We can call this type of function within PL/SQL block.
Can the function return more than one value?
From a function, we can have only one return statement. But we can send more than one value as a
part of the Return. That means if we want to return more than one value, we can use the collection and
Ref Cursor as a return statement.
Data Type :
Scalar Data Type: Contains only one value.
Composite Data Type :
Collection: A collection is an ordered group of logically related elements. In a collection, the internal component always has the same data type.
Records: The internal component can have different data types in a record.
SQL: Structured Query Language. SQL is used to communicate with the database. There are different types of SQL.,
DDL: Data Definition Language. Create, Alter, Drop, Truncate. All the DDL are auto-commit.
DML: Data Manipulation Language. Insert, Update, Delete, Merge.
DCL: Data Control Language. Grant, Revoke.
TCL: Transaction Control Language. Commit, Rollback, Savepoint.
DRL: Data Retrieval Language. Select.
Table Function & Pipelined Function: Both Table Function & Pipelined Function returns collection to the caller, and the function can be used as if it's a table.
The Table function loads all the values into the collection, and finally, the collection is returned to the caller.
The pipelined function returns the value as and when the value is ready to send back to the caller.
Commit Inside Trigger: Normally, we can't use Commit within the trigger. But if we use Pragma autonomous_transaction within the trigger, we use Commit within the trigger.
Calling a function having DML Statement in a Select statement: Normally, we can't call a function within a select statement with a DML statement. But if we use Pragma autonomous_transaction within the function, we can call this function within the select statement.
How can we get unique records without using Distinct in oracle?
We can use unique keywords in the select statement. (select unique roll, name from sts). We can use group by clause. We can also use unique records by using the Union keyword. We can also use intersect and Analytical functions (ROW_NUMBER(), RANK()).
Data Integrity: Data integrity adherence to business rules.
Delete duplicate records:
1. By using ROWID we can delete duplicate rows. For defining specific rows we can use the aggregate function max or min. Example :
select * from emp where rowid not in(select max(rowid), empno, empname from emp
group by empno, empname);
2. By using co-related subquery we can also delete duplicate rows.
Cursor: A cursor is a private memory area where data is stored temporarily and processing a specific select or DML statement.
LISTAGG: By using the LISTAGG function we can convert the Row value into a column value. But we can convert only 4000 bytes. If the value is greater than 4000 bytes then it will give an error. By using ON OVERFLOW TRUNCATE we can avoid this error. Syntex:
LISTAGG(EMP_NAME,',') GROUP WITHIN (ORDER BY EMP_NAME)
LISTAGG(EMP_NAME,',' ON OVERFLOW TRUNCATE) GROUP WITHIN (ORDER BY EMP_NAME)
IDENTITY COLUMN: If we use the IDENTITY keyword in table creation then oracle will automatically generate an auto number. There are three options available for IDENTITY.
1. Generated always as identity (not allowed manually insert)
2. Generated by default as identity(It can allow manually insert value but not allow null value)
3. Generated by default on null as identity(It will allow null value but if we insert null value then it will automatically insert value)
Regular Expression: There are five Regular Expression support Oracle.
1.REGEXP_LIKE
2. REGEXP_COUNT
3. REGEXP_INSTR
4. REGEXP_REPLACE
5. REGEXP_SUBSTR
How SQL Statement works internally in Oracle?
When the Oracle database server receives the SQL statement the database server processes the statement in a sequence of steps:
1. Syntax Check: Check the SQL statement for syntactic validity(All keywords are present).
2. Semantic Check: (Priviledge check,Object existence,Dependancy Check) A semantic check determines whether objects used in the SQL statement is meaningful, for eg, whether accessed tables and column exists in the database. If the mentioned table or object is invalid or not present in the database the Oracle database throws an appropriate exception to the caller.
3. Shared Pool Check: In case if exactly the same statement was previously executed by Oracle, then all the execution-related information will be available in the shared pool memory then oracle will reuse the same information for executing the statement again otherwise, oracle will proceed with the next set of processes.
4. Optimization: Generate multiple execution plans, and compare and pick the optimal plan for execution.
5. Row source generation: Oracle will generate the step wise execution plan which will be given as an input to the executor.
6. Execution : Executor Execute the statement and send back the result to user.
Interview questions for SQL Developer:
1) what is the query optimization technique in Oracle?
2) What are the types of SQL joins, and when would you use each one?
3) what are the global temporary tables?
4) what are the constraints? what are its types?
5) Diff between union and union all?
6) Query to display an even number of records?
7) Query to display the employee whose name starts with S?
8) Query to display the name of the employee, which contains M in any position in their name?
9) How to delete duplicate records?
10) What is an index, and how can it improve query performance?
11) What is normalization? Explain the first normal form and second normal form?
12) Diff between varchar and varchar2?
13) Write a query to display the current date?
14) Refresh types in materialized view?-dbms_mview.refresh
15) Diff between a clustered and a non-clustered index in SQL?
16) Diff between delete and truncate?
17) What are views? Types of views?
18) Explain the candidate key, primary key, and super key?
19) Explain the concept of a self-join in SQL and when it might be used?
20) What is the dual table?
21) What is Explain plan?
22) What are Oracle hints?
23) Different types of SQL commands?
24) Diff between exists and in?
25) Oracle 11g, 12c, 19c features?
26) What are window functions? Explain with examples?
27) What is synonyms? Types of synonyms?
28) Diff between decode and case?
29) Diff between view and materialized view?
30) What is inline view?
31) What are the analytical functions?
32) Diff between left outer join and right outer join?
33) What are the different types of subqueries in SQL and how are they used?
34) what are the joins? types of joins?
35) what is diff between DDL and DML?
36) what are the union, unionall, intersect, minus operators?
37) how to find list of the indexes for a given table?
38) what are the benefits and drawbacks of indexes?
39) what is function based index?
40) what are partitions? explain diff types?
41) what is substr() , instr() functions?
42) query to find nth highest salary?
43) diff between nvl, nvl2 and coalsce function?
44) diff between replace and translate?
45) what is with check option clause in view? what is force view?
46) Explain on delete cascade?
47) what is pivot function?
48) what is explain plan?
49) how to update complex view?
50) how to get unique records without using distinct clause?