Thursday, November 1, 2012

SQL Server interview questions, -Set 02





What is Log Shipping?

Log shipping defines the process for automatically taking backup of the database and transaction files on a SQL Server and then restoring them on a standby/backup server. This keeps the two SQL Server instances in sync with each other. In case production server fails, users simply need to be pointed to the standby/backup server. Log shipping primarily consists of 3 operations:
Backup transaction logs of the Production server.
Copy these logs on the standby/backup server.
Restore the log on standby/backup server.
What is the difference between a Local and a Global temporary table?

Temporary tables are used to allow short term use of data in SQL Server. They are of 2 types:
Local
Global
Only available to the current Db connection for current user and are cleared when connection is closed.
Available to any connection once created. They are cleared when the last connection is closed.
Multiple users can’t share a local temporary table.
Can be shared by multiple user sessions.


What is the STUFF and how does it differ from the REPLACE function?

Both STUFF and REPLACE are used to replace characters in a string.
 
select replace('abcdef','ab','xx') results in xxcdef
 
select replace('defdefdef','def','abc') results in abcabcabc
We cannot replace a specific occurrence of “def” using REPLACE.
 
select stuff('defdefdef',4, 3,'abc') results in defabcdef
 
where 4 is the character to begin replace from and 3 is the number of characters to replace.


What are the rules to use the ROWGUIDCOL property to define a globally unique identifier column?

Only one column can exist per table that is attached with ROWGUIDCOL property. One can then use $ROWGUID instead of column name in select list.


What is the actions prevented once referential integrity is enforced?

Actions prevented are:
·         Breaking of relationships is prevented once referential integrity on a database is enforced.
·         Can’t delete a row from primary table if there are related rows in secondary table.
·         Can’t update primary table’s primary key if row being modified has related rows in secondary table.
·         Can’t insert a new row in secondary table if there are not related rows in primary table.
·         Can’t update secondary table’s foreign key if there is no related row in primary table.


What are the commands available for Summarizing Data in SQL Server?

Commands for summarizing data in SQL Server:
Command
Description
Syntax/Example
SUM
Sums related values
SELECT SUM(Sal) as Tot from Table1;
AVG
Average value
SELECT AVG(Sal) as Avg_Sal from Table1;
COUNT
Returns number of rows of resultset
SELECT COUNT(*) from Table1;
MAX
Returns max value from a resultset
SELECT MAX(Sal) from Table1;
MIN
Returns min value from a resultset
SELECT MIN(Sal) from Table1;
GROUP BY
Arrange resultset in groups
SELECT ZIP,City FROM Emp GROUP BY ZIP
ORDER BY
Sort resultset
SELECT ZIP,City FROM Emp ORDER BY City
List out the difference between CUBE operator and ROLLUP operator

Difference between CUBE and ROLLUP:
CUBE
ROLLUP
It’s an additional switch to GROUP BY clause. It can be applied to all aggregation functions to return cross tabular result sets. .
It’s an extension to GROUP BY clause. It’s used to extract statistical and summarized information from result sets. It creates groupings and then applies aggregation functions on them.
Produces all possible combinations of subtotals specified in GROUP BY clause and a Grand Total.
Produces only some possible subtotal combinations.


What are the guidelines to use bulk copy utility of SQL Server?

Bulk copy is an API that allows interacting with SQL Server to export/import data in one of the two data formats. Bulk copy needs sufficient system credentials.
·         Need INSERT permissions on destination table while importing.
·         Need SELECT permissions on source table while exporting.
·         Need SELECT permissions on sysindexes, sysobjects and syscolumns tables.
bcp.exe northwind..cust out "c:\cust.txt" –c -T
Export all rows in Northwind.Cust table to an ASCII-character formatted text file.
 What are the capabilities of Cursors?

Capabilities of cursors:
·         Cursor reads every row one by one.
·         Cursors can be used to update a set of rows or a single specific row in a resultset
·         Cursors can be positioned to specific rows.
·         Cursors can be parameterized and hence are flexible.
·         Cursors lock row(s) while updating them.


What are the ways to controlling Cursor Behavior?

There are 2 ways to control Cursor behavior:
·         Cursor Types: Data access behavior depends on the type of cursor; forward only, static, keyset-drive and dynamic.
·         Cursor behaviors: Keywords such as SCROLL and INSENSITIVE along with the Cursor declaration define scrollability and sensitivity of the cursor.


What are the advantages of using Stored Procedures?

Advantages of using stored procedures are:
·         They are easier to maintain and troubleshoot as they are modular.
·         Stored procedures enable better tuning for performance.
·         Using stored procedures is much easier from a GUI end than building/using complex queries.
·         They can be part of a separate layer which allows separating the concerns. Hence Database layer can be handled by separate developers proficient in database queries.
·         Help in reducing network usage.
·         Provides more scalability to an application.
·         Reusable and hence reduce code.


What are the ways to code efficient transactions?

Some ways and guidelines to code efficient transactions:
·         Do not ask for an input from a user during a transaction.
·         Get all input needed for a transaction before starting the transaction.
·         Transaction should be atomic
·         Transactions should be as short and small as possible.
·         Rollback a transaction if a user intervenes and re-starts the transaction.
·         Transaction should involve a small amount of data as it needs to lock the number of rows involved.
·         Avoid transactions while browsing through data.
What are the differences among batches, stored procedures, and triggers?
               
Batch
Stored Procedure
Triggers
Collection or group of SQL statements. All statements of a batch are compiled into one executional unit called execution plan. All statements are then executed statement by statement.
It’s a collection or group of SQL statements that’s compiled once but used many times.
It’s a type of Stored procedure that cannot be called directly. Instead it fires when a row is updated, deleted, or inserted.


What security features are available for stored procedures?

Security features for stored procedures:
·         Grants users permissions to execute a stored procedure irrespective of the related tables.
·         Grant users users permission to work with a stored procedure to access a restricted set of data yet no give them permissions to update or select underlying data.
·         Stored procedures can be granted execute permissions rather than setting permissions on data itself.
·         Provide more granular security control through stored procedures rather than complete control on underlying data in tables.


What are the instances when triggers are appropriate?

Scenarios for using triggers:
·         To create a audit log of database activity.
·         To apply business rules.
·         To apply some calculation on data from tables which is not stored in them.
·         To enforce referential integrity.
·         Alter data in a third party application
·         To execute SQL statements as a result of an event/condition automatically.
What are the restrictions applicable while creating views?

Restrictions applicable while creating views:
·         A view cannot be indexed.
·         A view cannot be Altered or renamed. Its columns cannot be renamed.
·         To alter a view, it must be dropped and re-created.
·         ANSI_NULLS and QUOTED_IDENTIFIER options should be turned on to create a view.
·         All tables referenced in a view must be part of the same database.
·         Any user defined functions referenced in a view must be created with SCHEMABINDING option.
·         Cannot use ROWSET, UNION, TOP, ORDER BY, DISTINCT, COUNT(*), COMPUTE, COMPUTE BY in views.

What are the events recorded in a transaction log?

Events recorded in a transaction log:
·         Broker event category includes events produced by Service Broker.
·         Cursors event category includes cursor operations events.
·         CLR event category includes events fired by .Net CLR objects.
·         Database event category includes events of data.log files shrinking or growing on their own.
·         Errors and Warning         event category includes SQL Server warnings and errors.
·         Full text event category include events occurred when text searches are started, interrupted, or stopped.
·         Locks event category includes events caused when a lock is acquired, released, or cancelled.
·         Object event category includes events of database objects being created, updated or deleted.
·          OLEDB event category includes events caused by OLEDB calls.
·         Performance event category includes events caused by DML operators.
·         Progress report event category includes Online index operation events.
·         Scans event category includes events notifying table/index scanning.
·         Security audit event category includes audit server activities.
·         Server event category includes server events.
·         Sessions event category includes connecting and disconnecting events of clients to SQL Server.
·         Stored procedures event category includes events of execution of Stored procedures.
·         Transactions event category includes events related to transactions.
·         TSQL event category includes events generated while executing TSQL statements.
·         User configurable event category includes user defined events.


Describe when checkpoints are created in a transaction log.

Activities causing checkpoints are:
·         When a checkpoint is explicitly executed.
·         A logged operation is performed on the database.
·         Database files have been altered using Alter Database command.
·         SQL Server has been stopped explicitly or on its own.
·         SQL Server periodically generates checkpoints.
·         Backup of a database is taken.


Define Truncate and Delete commands.

TRUNCATE
DELETE
This is also a logged operation but in terms of deallocation of data pages.
This is a logged operation for every row.
Cannot TRUNCATE a table that has foreign key constraints.
Any row not violating a constraint can be Deleted.
Resets identity column to the default starting value.
Does not reset the identity column. Starts where it left from last.
Removes all rows from a table.
Used delete all or selected rows from a table based on WHERE clause.
Cannot be Rolled back.
Need to Commit or Rollback
DDL command
DML command



Please Share it! :)

Ditulis Oleh : Nangraj Hari: 7:24 AM Kategori:

0 comments:

Post a Comment

 
PLEASE VISIT MY OTHER BLOG TO DOWNLOAD LATEST FULL CRACKED SOFTWARES,GAMES,COMPUTER NOTES,VIDEO TUTORIALS,AND MUCH MORECLICK HERE