I hope everyone knows , in Sql Server the data are stored in the data pages.
HEAP:
A table with no clustered index is called a heap.
Consider a table ‘test’ which contain two columns ID, Name which doesn’t contain a Clustered index. So the data stored in the data page is same as we see in the table.
TABLE
ID | NAME |
4 | A |
5 | B |
3 | C |
1 | D |
Data Page
ID | NAME |
4 | A |
5 | B |
3 | C |
1 | D |
Clustered Index:
If we put a clustered index on the column ID i.e. here Primary key, then the data stored in the data pages in a sorted order of the column specified. The clustered index are organized as
B-trees. Each page in an index B-tree is called an index node. The top node of the B-tree is called the root node. The bottom level of nodes in the index is called the leaf nodes. Any index levels between the root and the leaf nodes are collectively known as intermediate levels. The leaf node contains the data pages.
TABLE
ID(PK) | NAME |
4 | A |
5 | B |
3 | C |
1 | D |
Data Page
In data page the data is stores as follows,
ID(PK) | NAME |
1 | D |
3 | C |
4 | A |
5 | B |
Non-Clustered Index:
Non clustered index also organized as the B-tree Structure.
- The data rows of the underlying table are not sorted and stored in order based on their non-clustered keys.
- The leaf layer of a non-clustered index is made up of index pages instead of data pages.
- If the table is heap, the row locater is a pointer to the row.
- If the table is having the clustered index ,the row-locater is the clustered index key.
Reference & Images: http://msdn.microsoft.com/en-us/library/ms177443.aspx
If you like this post Please make a comment.
Rejeesh
15 years agoset ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
GO
alter PROCEDURE [dbo].[stockfromoptocurrent]
@bfDate int,
@curDate int,
@OrderType smallint,
@OrderNet tinyint,
@DeptCode int,
@ProdCode int,
@OrderNo float,
@databasenm varchar(50)
AS
BEGIN
SELECT SUM(StockTypeCode1) AS Qty
FROM @databasenm.dbo.ProductTransactions
WHERE (DocDt BETWEEN @bfDate AND @curDate)
GROUP BY DeptCode, OrderNo, OrderNoNtCode, OrderType, ProdCode
HAVING (DeptCode = @DeptCode) AND (OrderNo = @OrderNo) AND (OrderNoNtCode = @OrderNet) AND (OrderType = @OrderType) AND (ProdCode = @ProdCode)
END
————
here i want to pass @databasenm as current financial year database
please help
———
balu
15 years agoThanks, but if we aplly a composite primary key on a table than clustered index how it will works