|
|
DB
Interview Questions
Q: |
What
is SQL? |
A: |
SQL stands for 'Structured Query Language'. |
|
|
Q: |
What
is SELECT statement? |
A: |
The SELECT statement lets you select a set of values
from a table in a database. The values selected
from the database table would depend on
the various conditions that are specified
in the SQL query. |
|
|
Q: |
How can you compare a part of the name rather than
the entire name? |
A: |
SELECT * FROM people WHERE empname LIKE '%ab%'
Would return a recordset with records
consisting empname the sequence 'ab' in empname . |
|
|
Q: |
What is the INSERT statement?
|
A: |
The INSERT statement lets you insert information into
a database. |
|
|
Q: |
How do you delete a record from a database?
|
A: |
Use the DELETE statement to remove records or any particular
column values from a database. |
|
|
Q: |
How
could I get distinct entries from a table? |
A: |
The SELECT statement in conjunction with DISTINCT lets
you select a set of distinct values from
a table in a database. The values selected
from the database table would of course
depend on the various conditions that are
specified in the SQL query. Example
SELECT DISTINCT empname FROM emptable |
|
|
Q: |
How
to get the results of a Query
sorted in any order? |
A: |
You can
sort the results and return the sorted results
to your program by using ORDER BY keyword
thus saving you the pain of carrying out
the sorting yourself. The ORDER BY keyword
is used for sorting.
SELECT empname, age, city FROM emptable
ORDER BY empname |
|
|
Q: |
How can I find the total number of records
in a table? |
A: |
You could use the COUNT keyword , example
SELECT COUNT(*) FROM emp WHERE age>40 |
|
|
Q: |
What
is GROUP BY? |
A: |
The GROUP BY keywords have been added to SQL because
aggregate functions (like SUM) return the
aggregate of all column values every time
they are called. Without the GROUP BY functionality,
finding the sum for each individual group
of column values was not possible. |
|
|
Q: |
What
is the difference among "dropping a table",
"truncating a table" and "deleting all
records" from a table. |
A: |
Dropping
: (Table structure
+ Data are deleted), Invalidates
the dependent objects
,Drops the indexes
Truncating:
(Data alone deleted), Performs
an automatic commit, Faster
than delete
Delete :
(Data alone deleted), Doesn’t perform
automatic commit
|
|
|
Q: |
What
are the Large object types suported by
Oracle? |
A: |
Blob
and Clob. |
|
|
Q: |
Difference
between a "where" clause and
a "having" clause. |
A: |
Having
clause is used only with group functions
whereas Where is not used with. |
|
|
Q: |
What's
the difference between a primary key and
a unique key? |
A: |
Both
primary key and unique enforce uniqueness
of the column on which they are defined.
But by default primary key creates a clustered
index on the column, where are unique
creates a nonclustered index by default.
Another major difference is that, primary
key doesn't allow NULLs, but unique key
allows one NULL only. |
|
|
Q: |
What
are cursors? Explain different types of
cursors. What are the disadvantages of
cursors? How can you avoid cursors? |
A: |
Cursors
allow row-by-row prcessing of the resultsets.
Types
of cursors: Static, Dynamic, Forward-only,
Keyset-driven. See books online for more
information.
Disadvantages
of cursors: Each time you fetch a row
from the cursor, it results in a network
roundtrip, where as a normal SELECT query
makes only one rowundtrip, however large
the resultset is. Cursors are also costly
because they require more resources and
temporary storage (results in more IO
operations). Furthere, there are restrictions
on the SELECT statements that can be used
with some types of cursors.
Most
of the times, set based operations can
be used instead of cursors.
|
|
|
Q: |
What
are triggers? How to invoke a trigger
on demand? |
A: |
Triggers
are special kind of stored procedures that
get executed automatically when an INSERT,
UPDATE or DELETE operation takes place on
a table.
Triggers
can't be invoked on demand. They get triggered
only when an associated action (INSERT,
UPDATE, DELETE) happens on the table on
which they are defined.
Triggers
are generally used to implement business
rules, auditing. Triggers can also be
used to extend the referential integrity
checks, but wherever possible, use constraints
for this purpose, instead of triggers,
as constraints are much faster.
|
Q: |
What
is a join and explain different types
of joins. |
A: |
Joins are used in queries to explain
how different tables are related. Joins
also let you select data from a table
depending upon data from another table.
Types of joins: INNER JOINs, OUTER JOINs,
CROSS JOINs. OUTER JOINs are further classified
as LEFT OUTER JOINS, RIGHT OUTER JOINS
and FULL OUTER JOINS.
|
|
|
Q: |
What
is a self join? |
A: |
Self
join is just like any other join, except
that two instances of the same table will
be joined in the query. |
|
|
|
|