SQL SERVER Interview Questions-part1
- What
     is denormalization and when would you go for it?
     As the name indicates, denormalization
     is the reverse process of normalization. It's the controlled introduction
     of redundancy in to the database design. It helps improve the query
     performance as the number of joins could be reduced. 
- How
     do you implement one-to-one, one-to-many and many-to-many relationships
     while designing tables?
     One-to-One relationship can be
     implemented as a single table and rarely as two tables with primary and
     foreign key relationships. One-to-Many relationships are implemented by
     splitting the data into two tables with primary key and foreign key
     relationships. Many-to-Many relationships are implemented using a junction
     table with the keys from both the tables forming the composite primary key
     of the junction table.  
- What's
     the difference between a primary key and a unique key?
     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.  
- What
     are user defined datatypes and when you should go for them?
     User defined datatypes let you extend
     the base SQL Server datatypes by providing a descriptive name, and format
     to the database. Take for example, in your database, there is a column
     called ZIP_Code which appears in many tables. In all these tables it
     should be varchar(6). In this case you could create a user defined
     datatype called ZIP_Code_Type of varchar(6) and use it across all your
     tables.  
- What
     is bit datatype and what's the information that can be stored inside a bit
     column?
     Bit datatype is used to store boolean
     information like 1 or 0 (true or false). Untill SQL Server 6.5 bit
     datatype could hold either a 1 or 0 and there was no support for NULL. But
     from SQL Server 7.0 onwards, bit datatype can represent a third state,
     which is NULL.  
- Define
     candidate key, alternate key, composite key.
     A candidate key is one that can
     identify each row of a table uniquely. Generally a candidate key becomes
     the primary key of the table. If the table has more than one candidate
     key, one of them will become the primary key, and the rest are called alternate
     keys. A key formed by combining at least two or more columns is called
     composite key.  
- What
     are defaults? Is there a column to which a default can't be bound?
     A default is a value that will be used
     by a column, if no value is supplied to that column while inserting data.
     IDENTITY columns and timestamp columns can't have defaults bound to them.
     See CREATE DEFUALT in books online.  
- What
     is a transaction and what are ACID properties?
     A transaction is a logical unit of
     work in which, all the steps must be performed or none. ACID stands for
     Atomicity, Consistency, Isolation, Durability. These are the properties of
     a transaction. For more information and explanation of these properties,
     see SQL Server books online or any RDBMS fundamentals text book.  
- Explain
     different isolation levels An isolation level determines the degree of
     isolation of data between concurrent transactions.
     The default SQL Server isolation level
     is Read Committed. Here are the other isolation levels (in the ascending
     order of isolation): Read Uncommitted, Read Committed, Repeatable Read,
     Serializable.  
- How
     does .NET and SQL SERVER thread is work?
     There are two types of threading
     pre-emptive and Non-preemptive but Sql Server support Non-preemptive and
     .NET thread model is different. Because Sql have to handle thread in
     different way for SQLCLR this different thread are known as Tasking of
     Threads . In this thread there is a switch between SQLCLR and SQL SERVER
     threads .SQL SERVER uses blocking points for transition to happen between
     SQLCLR and SQL SERVER threads.