Arman's blog

Paging T-SQL Query Results

Today I’m going to show how to do paging with T-SQL query. 

In case of SELECT query, if the amount of data returned by the query is too large then it may create performance issues. For optimization, we often split the result in several sections or pages. For this purpose we can use a new function added in SQL Server 2005 called ROW_NUMBER().

ROW_NUMBER ( )     OVER ( [ <partition_by_clause> ] <order_by_clause> )

The function ROW_NUMBER is not available in SQL Server 2000.

Following is a normal SELECT query which returns all the available rows in the Customers table.

SELECT * FROM CUSTOMERS
 
CustomerID CompanyName                              ContactName                    ContactTitle                   Address                                                      City            Region          PostalCode Country         Phone                    Fax
---------- ---------------------------------------- ------------------------------ ------------------------------ ------------------------------------------------------------ --------------- --------------- ---------- --------------- ------------------------ ------------------------
ALFKI      Alfreds Futterkiste                      Maria Anders                   Sales Representative           Obere Str. 57                                                Berlin          NULL            12209      Germany         030-0074321              030-0076545
ANATR      Ana Trujillo Emparedados y helados       Ana Trujillo                   Owner                          Avda. de la Constitución 2222                                México D.F.     NULL            05021      Mexico          (5) 555-4729             (5) 555-3745
ANTON      Antonio Moreno Taquería                  Antonio Moreno                 Owner                          Mataderos  2312                                              México D.F.     NULL            05023      Mexico          (5) 555-3932             NULL
AROUT      Around the Horn                          Thomas Hardy                   Sales Representative           120 Hanover Sq.                                              London          NULL            WA1 1DP    UK              (171) 555-7788           (171) 555-6750
BERGS      Berglunds snabbköp                       Christina Berglund             Order Administrator            Berguvsvägen  8                                              Luleå           NULL            S-958 22   Sweden          0921-12 34 65            0921-12 34 67
BLAUS      Blauer See Delikatessen                  Hanna Moos                     Sales Representative           Forsterstr. 57                                               Mannheim        NULL            68306      Germany         0621-08460               0621-08924
BLONP      Blondesddsl père et fils                 Frédérique Citeaux             Marketing Manager              24, place Kléber                                             Strasbourg      NULL            67000      France          88.60.15.31              88.60.15.32
BOLID      Bólido Comidas preparadas                Martín Sommer                  Owner                          C/ Araquil, 67                                               Madrid          NULL            28023      Spain           (91) 555 22 82           (91) 555 91 99
BONAP      Bon app'                                 Laurence Lebihan               Owner                          12, rue des Bouchers                                         Marseille       NULL            13008      France          91.24.45.40              91.24.45.41
BOTTM      Bottom-Dollar Markets                    Elizabeth Lincoln              Accounting Manager             23 Tsawassen Blvd.                                           Tsawassen       BC              T2F 8M4    Canada          (604) 555-4729           (604) 555-3745
BSBEV      B's Beverages                            Victoria Ashworth              Sales Representative           Fauntleroy Circus                                            London          NULL            EC2 5NT    UK              (171) 555-1212           NULL
CACTU      Cactus Comidas para llevar               Patricio Simpson               Sales Agent                    Cerrito 333                                                  Buenos Aires    NULL            1010       Argentina       (1) 135-5555             (1) 135-4892
CENTC      Centro comercial Moctezuma               Francisco Chang                Marketing Manager              Sierras de Granada 9993                                      México D.F.     NULL            05022      Mexico          (5) 555-3392             (5) 555-7293
CHOPS      Chop-suey Chinese                        Yang Wang                      Owner                          Hauptstr. 29                                                 Bern            NULL            3012       Switzerland     0452-076545              NULL
COMMI      Comércio Mineiro                         Pedro Afonso                   Sales Associate                Av. dos Lusíadas, 23                                         Sao Paulo       SP              05432-043  Brazil          (11) 555-7647            NULL
CONSH      Consolidated Holdings                    Elizabeth Brown                Sales Representative           Berkeley Gardens 12  Brewery                                 London          NULL            WX1 6LT    UK              (171) 555-2282           (171) 555-9199
DRACD      Drachenblut Delikatessen                 Sven Ottlieb                   Order Administrator            Walserweg 21                                                 Aachen          NULL            52066      Germany         0241-039123              0241-059428
DUMON      Du monde entier                          Janine Labrune                 Owner                          67, rue des Cinquante Otages                                 Nantes          NULL            44000      France          40.67.88.88              40.67.89.89
EASTC      Eastern Connection                       Ann Devon                      Sales Agent                    35 King George                                               London          NULL            WX3 6FW    UK              (171) 555-0297           (171) 555-3373
ERNSH      Ernst Handel                             Roland Mendel                  Sales Manager                  Kirchgasse 6                                                 Graz            NULL            8010       Austria         7675-3425                7675-3426
FAMIA      Familia Arquibaldo                       Aria Cruz                      Marketing Assistant            Rua Orós, 92                                                 Sao Paulo       SP              05442-030  Brazil          (11) 555-9857            NULL
FISSA      FISSA Fabrica Inter. Salchichas S.A.     Diego Roel                     Accounting Manager             C/ Moralzarzal, 86                                           Madrid          NULL            28034      Spain           (91) 555 94 44           (91) 555 55 93
FOLIG      Folies gourmandes                        Martine Rancé                  Assistant Sales Agent          184, chaussée de Tournai                                     Lille           NULL            59000      France          20.16.10.16              20.16.10.17
FOLKO      Folk och fä HB                           Maria Larsson                  Owner                          Åkergatan 24                                                 Bräcke          NULL            S-844 67   Sweden          0695-34 67 21            NULL
FRANK      Frankenversand                           Peter Franken                  Marketing Manager              Berliner Platz 43                                            München         NULL            80805      Germany         089-0877310              089-0877451
FRANR      France restauration                      Carine Schmitt                 Marketing Manager              54, rue Royale                                               Nantes          NULL            44000      France          40.32.21.21              40.32.21.20
FRANS      Franchi S.p.A.                           Paolo Accorti                  Sales Representative           Via Monte Bianco 34                                          Torino          NULL            10100      Italy           011-4988260              011-4988261
FURIB      Furia Bacalhau e Frutos do Mar           Lino Rodriguez                 Sales Manager                  Jardim das rosas n. 32                                       Lisboa          NULL            1675       Portugal        (1) 354-2534             (1) 354-2535
GALED      Galería del gastrónomo                   Eduardo Saavedra               Marketing Manager              Rambla de Cataluña, 23                                       Barcelona       NULL            08022      Spain           (93) 203 4560            (93) 203 4561
GODOS      Godos Cocina Típica                      José Pedro Freyre              Sales Manager                  C/ Romero, 33                                                Sevilla         NULL            41101      Spain           (95) 555 82 82           NULL
GOURL      Gourmet Lanchonetes                      André Fonseca                  Sales Associate                Av. Brasil, 442                                              Campinas        SP              04876-786  Brazil          (11) 555-9482            NULL
GREAL      Great Lakes Food Market                  Howard Snyder                  Marketing Manager              2732 Baker Blvd.                                             Eugene          OR              97403      USA             (503) 555-7555           NULL
GROSR      GROSELLA-Restaurante                     Manuel Pereira                 Owner                          5ª Ave. Los Palos Grandes                                    Caracas         DF              1081       Venezuela       (2) 283-2951             (2) 283-3397
HANAR      Hanari Carnes                            Mario Pontes                   Accounting Manager             Rua do Paço, 67                                              Rio de Janeiro  RJ              05454-876  Brazil          (21) 555-0091            (21) 555-8765
HILAA      HILARION-Abastos                         Carlos Hernández               Sales Representative           Carrera 22 con Ave. Carlos Soublette #8-35                   San Cristóbal   Táchira         5022       Venezuela       (5) 555-1340             (5) 555-1948
HUNGC      Hungry Coyote Import Store               Yoshi Latimer                  Sales Representative           City Center Plaza 516 Main St.                               Elgin           OR              97827      USA             (503) 555-6874           (503) 555-2376
HUNGO      Hungry Owl All-Night Grocers             Patricia McKenna               Sales Associate                8 Johnstown Road                                             Cork            Co. Cork        NULL       Ireland         2967 542                 2967 3333
ISLAT      Island Trading                           Helen Bennett                  Marketing Manager              Garden House Crowther Way                                    Cowes           Isle of Wight   PO31 7PJ   UK              (198) 555-8888           NULL
KOENE      Königlich Essen                          Philip Cramer                  Sales Associate                Maubelstr. 90                                                Brandenburg     NULL            14776      Germany         0555-09876               NULL
LACOR      La corne d'abondance                     Daniel Tonini                  Sales Representative           67, avenue de l'Europe                                       Versailles      NULL            78000      France          30.59.84.10              30.59.85.11
LAMAI      La maison d'Asie                         Annette Roulet                 Sales Manager                  1 rue Alsace-Lorraine                                        Toulouse        NULL            31000      France          61.77.61.10              61.77.61.11
LAUGB      Laughing Bacchus Wine Cellars            Yoshi Tannamuri                Marketing Assistant            1900 Oak St.                                                 Vancouver       BC              V3F 2K1    Canada          (604) 555-3392           (604) 555-7293
LAZYK      Lazy K Kountry Store                     John Steel                     Marketing Manager              12 Orchestra Terrace                                         Walla Walla     WA              99362      USA             (509) 555-7969           (509) 555-6221
LEHMS      Lehmanns Marktstand                      Renate Messner                 Sales Representative           Magazinweg 7                                                 Frankfurt a.M.  NULL            60528      Germany         069-0245984              069-0245874
LETSS      Let's Stop N Shop                        Jaime Yorres                   Owner                          87 Polk St. Suite 5                                          San Francisco   CA              94117      USA             (415) 555-5938           NULL
LILAS      LILA-Supermercado                        Carlos González                Accounting Manager             Carrera 52 con Ave. Bolívar #65-98 Llano Largo               Barquisimeto    Lara            3508       Venezuela       (9) 331-6954             (9) 331-7256
LINOD      LINO-Delicateses                         Felipe Izquierdo               Owner                          Ave. 5 de Mayo Porlamar                                      I. de Margarita Nueva Esparta   4980       Venezuela       (8) 34-56-12             (8) 34-93-93
LONEP      Lonesome Pine Restaurant                 Fran Wilson                    Sales Manager                  89 Chiaroscuro Rd.                                           Portland        OR              97219      USA             (503) 555-9573           (503) 555-9646
MAGAA      Magazzini Alimentari Riuniti             Giovanni Rovelli               Marketing Manager              Via Ludovico il Moro 22                                      Bergamo         NULL            24100      Italy           035-640230               035-640231
MAISD      Maison Dewey                             Catherine Dewey                Sales Agent                    Rue Joseph-Bens 532                                          Bruxelles       NULL            B-1180     Belgium         (02) 201 24 67           (02) 201 24 68
MEREP      Mère Paillarde                           Jean Fresnière                 Marketing Assistant            43 rue St. Laurent                                           Montréal        Québec          H1J 1C3    Canada          (514) 555-8054           (514) 555-8055
MORGK      Morgenstern Gesundkost                   Alexander Feuer                Marketing Assistant            Heerstr. 22                                                  Leipzig         NULL            04179      Germany         0342-023176              NULL
NORTS      North/South                              Simon Crowther                 Sales Associate                South House 300 Queensbridge                                 London          NULL            SW7 1RZ    UK              (171) 555-7733           (171) 555-2530
OCEAN      Océano Atlántico Ltda.                   Yvonne Moncada                 Sales Agent                    Ing. Gustavo Moncada 8585 Piso 20-A                          Buenos Aires    NULL            1010       Argentina       (1) 135-5333             (1) 135-5535
OLDWO      Old World Delicatessen                   Rene Phillips                  Sales Representative           2743 Bering St.                                              Anchorage       AK              99508      USA             (907) 555-7584           (907) 555-2880
OTTIK      Ottilies Käseladen                       Henriette Pfalzheim            Owner                          Mehrheimerstr. 369                                           Köln            NULL            50739      Germany         0221-0644327             0221-0765721
PARIS      Paris spécialités                        Marie Bertrand                 Owner                          265, boulevard Charonne                                      Paris           NULL            75012      France          (1) 42.34.22.66          (1) 42.34.22.77
PERIC      Pericles Comidas clásicas                Guillermo Fernández            Sales Representative           Calle Dr. Jorge Cash 321                                     México D.F.     NULL            05033      Mexico          (5) 552-3745             (5) 545-3745
PICCO      Piccolo und mehr                         Georg Pipps                    Sales Manager                  Geislweg 14                                                  Salzburg        NULL            5020       Austria         6562-9722                6562-9723
PRINI      Princesa Isabel Vinhos                   Isabel de Castro               Sales Representative           Estrada da saúde n. 58                                       Lisboa          NULL            1756       Portugal        (1) 356-5634             NULL
QUEDE      Que Delícia                              Bernardo Batista               Accounting Manager             Rua da Panificadora, 12                                      Rio de Janeiro  RJ              02389-673  Brazil          (21) 555-4252            (21) 555-4545
QUEEN      Queen Cozinha                            Lúcia Carvalho                 Marketing Assistant            Alameda dos Canàrios, 891                                    Sao Paulo       SP              05487-020  Brazil          (11) 555-1189            NULL
QUICK      QUICK-Stop                               Horst Kloss                    Accounting Manager             Taucherstraße 10                                             Cunewalde       NULL            01307      Germany         0372-035188              NULL
RANCH      Rancho grande                            Sergio Gutiérrez               Sales Representative           Av. del Libertador 900                                       Buenos Aires    NULL            1010       Argentina       (1) 123-5555             (1) 123-5556
RATTC      Rattlesnake Canyon Grocery               Paula Wilson                   Assistant Sales Representative 2817 Milton Dr.                                              Albuquerque     NM              87110      USA             (505) 555-5939           (505) 555-3620
REGGC      Reggiani Caseifici                       Maurizio Moroni                Sales Associate                Strada Provinciale 124                                       Reggio Emilia   NULL            42100      Italy           0522-556721              0522-556722
RICAR      Ricardo Adocicados                       Janete Limeira                 Assistant Sales Agent          Av. Copacabana, 267                                          Rio de Janeiro  RJ              02389-890  Brazil          (21) 555-3412            NULL
RICSU      Richter Supermarkt                       Michael Holz                   Sales Manager                  Grenzacherweg 237                                            Genève          NULL            1203       Switzerland     0897-034214              NULL
ROMEY      Romero y tomillo                         Alejandra Camino               Accounting Manager             Gran Vía, 1                                                  Madrid          NULL            28001      Spain           (91) 745 6200            (91) 745 6210
SANTG      Santé Gourmet                            Jonas Bergulfsen               Owner                          Erling Skakkes gate 78                                       Stavern         NULL            4110       Norway          07-98 92 35              07-98 92 47
SAVEA      Save-a-lot Markets                       Jose Pavarotti                 Sales Representative           187 Suffolk Ln.                                              Boise           ID              83720      USA             (208) 555-8097           NULL
SEVES      Seven Seas Imports                       Hari Kumar                     Sales Manager                  90 Wadhurst Rd.                                              London          NULL            OX15 4NB   UK              (171) 555-1717           (171) 555-5646
SIMOB      Simons bistro                            Jytte Petersen                 Owner                          Vinbæltet 34                                                 Kobenhavn       NULL            1734       Denmark         31 12 34 56              31 13 35 57
SPECD      Spécialités du monde                     Dominique Perrier              Marketing Manager              25, rue Lauriston                                            Paris           NULL            75016      France          (1) 47.55.60.10          (1) 47.55.60.20
SPLIR      Split Rail Beer & Ale                    Art Braunschweiger             Sales Manager                  P.O. Box 555                                                 Lander          WY              82520      USA             (307) 555-4680           (307) 555-6525
SUPRD      Suprêmes délices                         Pascale Cartrain               Accounting Manager             Boulevard Tirou, 255                                         Charleroi       NULL            B-6000     Belgium         (071) 23 67 22 20        (071) 23 67 22 21
THEBI      The Big Cheese                           Liz Nixon                      Marketing Manager              89 Jefferson Way Suite 2                                     Portland        OR              97201      USA             (503) 555-3612           NULL
THECR      The Cracker Box                          Liu Wong                       Marketing Assistant            55 Grizzly Peak Rd.                                          Butte           MT              59801      USA             (406) 555-5834           (406) 555-8083
TOMSP      Toms Spezialitäten                       Karin Josephs                  Marketing Manager              Luisenstr. 48                                                Münster         NULL            44087      Germany         0251-031259              0251-035695
TORTU      Tortuga Restaurante                      Miguel Angel Paolino           Owner                          Avda. Azteca 123                                             México D.F.     NULL            05033      Mexico          (5) 555-2933             NULL
TRADH      Tradição Hipermercados                   Anabela Domingues              Sales Representative           Av. Inês de Castro, 414                                      Sao Paulo       SP              05634-030  Brazil          (11) 555-2167            (11) 555-2168
TRAIH      Trail's Head Gourmet Provisioners        Helvetius Nagy                 Sales Associate                722 DaVinci Blvd.                                            Kirkland        WA              98034      USA             (206) 555-8257           (206) 555-2174
VAFFE      Vaffeljernet                             Palle Ibsen                    Sales Manager                  Smagsloget 45                                                Århus           NULL            8200       Denmark         86 21 32 43              86 22 33 44
VICTE      Victuailles en stock                     Mary Saveley                   Sales Agent                    2, rue du Commerce                                           Lyon            NULL            69004      France          78.32.54.86              78.32.54.87
VINET      Vins et alcools Chevalier                Paul Henriot                   Accounting Manager             59 rue de l'Abbaye                                           Reims           NULL            51100      France          26.47.15.10              26.47.15.11
WANDK      Die Wandernde Kuh                        Rita Müller                    Sales Representative           Adenauerallee 900                                            Stuttgart       NULL            70563      Germany         0711-020361              0711-035428
WARTH      Wartian Herkku                           Pirkko Koskitalo               Accounting Manager             Torikatu 38                                                  Oulu            NULL            90110      Finland         981-443655               981-443655
WELLI      Wellington Importadora                   Paula Parente                  Sales Manager                  Rua do Mercado, 12                                           Resende         SP              08737-363  Brazil          (14) 555-8122            NULL
WHITC      White Clover Markets                     Karl Jablonski                 Owner                          305 - 14th Ave. S. Suite 3B                                  Seattle         WA              98128      USA             (206) 555-4112           (206) 555-4115
WILMK      Wilman Kala                              Matti Karttunen                Owner/Marketing Assistant      Keskuskatu 45                                                Helsinki        NULL            21240      Finland         90-224 8858              90-224 8858
WOLZA      Wolski  Zajazd                           Zbyszek Piestrzeniewicz        Owner                          ul. Filtrowa 68                                              Warszawa        NULL            01-012     Poland          (26) 642-7012            (26) 642-7012

(91 row(s) affected)

 

How to get the Row Numbers ?

However, suppose I want to get the row numbers as well as the rows. Then I can use the following query to get it

SELECT  ROW_NUMBER() OVER (ORDER BY CustomerID ASC) AS Row, * FROM Customers

Check out the result of this query. See the row column at the left most side of this result.

Row                  CustomerID CompanyName                              ContactName                    ContactTitle                   Address                                                      City            Region          PostalCode Country         Phone                    Fax
-------------------- ---------- ---------------------------------------- ------------------------------ ------------------------------ ------------------------------------------------------------ --------------- --------------- ---------- --------------- ------------------------ ------------------------
1                    ALFKI      Alfreds Futterkiste                      Maria Anders                   Sales Representative           Obere Str. 57                                                Berlin          NULL            12209      Germany         030-0074321              030-0076545
2                    ANATR      Ana Trujillo Emparedados y helados       Ana Trujillo                   Owner                          Avda. de la Constitución 2222                                México D.F.     NULL            05021      Mexico          (5) 555-4729             (5) 555-3745
3                    ANTON      Antonio Moreno Taquería                  Antonio Moreno                 Owner                          Mataderos  2312                                              México D.F.     NULL            05023      Mexico          (5) 555-3932             NULL
4                    AROUT      Around the Horn                          Thomas Hardy                   Sales Representative           120 Hanover Sq.                                              London          NULL            WA1 1DP    UK              (171) 555-7788           (171) 555-6750
5                    BERGS      Berglunds snabbköp                       Christina Berglund             Order Administrator            Berguvsvägen  8                                              Luleå           NULL            S-958 22   Sweden          0921-12 34 65            0921-12 34 67
6                    BLAUS      Blauer See Delikatessen                  Hanna Moos                     Sales Representative           Forsterstr. 57                                               Mannheim        NULL            68306      Germany         0621-08460               0621-08924
7                    BLONP      Blondesddsl père et fils                 Frédérique Citeaux             Marketing Manager              24, place Kléber                                             Strasbourg      NULL            67000      France          88.60.15.31              88.60.15.32
8                    BOLID      Bólido Comidas preparadas                Martín Sommer                  Owner                          C/ Araquil, 67                                               Madrid          NULL            28023      Spain           (91) 555 22 82           (91) 555 91 99
9                    BONAP      Bon app'                                 Laurence Lebihan               Owner                          12, rue des Bouchers                                         Marseille       NULL            13008      France          91.24.45.40              91.24.45.41
10                   BOTTM      Bottom-Dollar Markets                    Elizabeth Lincoln              Accounting Manager             23 Tsawassen Blvd.                                           Tsawassen       BC              T2F 8M4    Canada          (604) 555-4729           (604) 555-3745
11                   BSBEV      B's Beverages                            Victoria Ashworth              Sales Representative           Fauntleroy Circus                                            London          NULL            EC2 5NT    UK              (171) 555-1212           NULL
12                   CACTU      Cactus Comidas para llevar               Patricio Simpson               Sales Agent                    Cerrito 333                                                  Buenos Aires    NULL            1010       Argentina       (1) 135-5555             (1) 135-4892
13                   CENTC      Centro comercial Moctezuma               Francisco Chang                Marketing Manager              Sierras de Granada 9993                                      México D.F.     NULL            05022      Mexico          (5) 555-3392             (5) 555-7293
14                   CHOPS      Chop-suey Chinese                        Yang Wang                      Owner                          Hauptstr. 29                                                 Bern            NULL            3012       Switzerland     0452-076545              NULL
15                   COMMI      Comércio Mineiro                         Pedro Afonso                   Sales Associate                Av. dos Lusíadas, 23                                         Sao Paulo       SP              05432-043  Brazil          (11) 555-7647            NULL
16                   CONSH      Consolidated Holdings                    Elizabeth Brown                Sales Representative           Berkeley Gardens 12  Brewery                                 London          NULL            WX1 6LT    UK              (171) 555-2282           (171) 555-9199
17                   DRACD      Drachenblut Delikatessen                 Sven Ottlieb                   Order Administrator            Walserweg 21                                                 Aachen          NULL            52066      Germany         0241-039123              0241-059428
18                   DUMON      Du monde entier                          Janine Labrune                 Owner                          67, rue des Cinquante Otages                                 Nantes          NULL            44000      France          40.67.88.88              40.67.89.89
19                   EASTC      Eastern Connection                       Ann Devon                      Sales Agent                    35 King George                                               London          NULL            WX3 6FW    UK              (171) 555-0297           (171) 555-3373
20                   ERNSH      Ernst Handel                             Roland Mendel                  Sales Manager                  Kirchgasse 6                                                 Graz            NULL            8010       Austria         7675-3425                7675-3426
21                   FAMIA      Familia Arquibaldo                       Aria Cruz                      Marketing Assistant            Rua Orós, 92                                                 Sao Paulo       SP              05442-030  Brazil          (11) 555-9857            NULL
22                   FISSA      FISSA Fabrica Inter. Salchichas S.A.     Diego Roel                     Accounting Manager             C/ Moralzarzal, 86                                           Madrid          NULL            28034      Spain           (91) 555 94 44           (91) 555 55 93
23                   FOLIG      Folies gourmandes                        Martine Rancé                  Assistant Sales Agent          184, chaussée de Tournai                                     Lille           NULL            59000      France          20.16.10.16              20.16.10.17
24                   FOLKO      Folk och fä HB                           Maria Larsson                  Owner                          Åkergatan 24                                                 Bräcke          NULL            S-844 67   Sweden          0695-34 67 21            NULL
25                   FRANK      Frankenversand                           Peter Franken                  Marketing Manager              Berliner Platz 43                                            München         NULL            80805      Germany         089-0877310              089-0877451
26                   FRANR      France restauration                      Carine Schmitt                 Marketing Manager              54, rue Royale                                               Nantes          NULL            44000      France          40.32.21.21              40.32.21.20
27                   FRANS      Franchi S.p.A.                           Paolo Accorti                  Sales Representative           Via Monte Bianco 34                                          Torino          NULL            10100      Italy           011-4988260              011-4988261
28                   FURIB      Furia Bacalhau e Frutos do Mar           Lino Rodriguez                 Sales Manager                  Jardim das rosas n. 32                                       Lisboa          NULL            1675       Portugal        (1) 354-2534             (1) 354-2535
29                   GALED      Galería del gastrónomo                   Eduardo Saavedra               Marketing Manager              Rambla de Cataluña, 23                                       Barcelona       NULL            08022      Spain           (93) 203 4560            (93) 203 4561
30                   GODOS      Godos Cocina Típica                      José Pedro Freyre              Sales Manager                  C/ Romero, 33                                                Sevilla         NULL            41101      Spain           (95) 555 82 82           NULL
31                   GOURL      Gourmet Lanchonetes                      André Fonseca                  Sales Associate                Av. Brasil, 442                                              Campinas        SP              04876-786  Brazil          (11) 555-9482            NULL
32                   GREAL      Great Lakes Food Market                  Howard Snyder                  Marketing Manager              2732 Baker Blvd.                                             Eugene          OR              97403      USA             (503) 555-7555           NULL
33                   GROSR      GROSELLA-Restaurante                     Manuel Pereira                 Owner                          5ª Ave. Los Palos Grandes                                    Caracas         DF              1081       Venezuela       (2) 283-2951             (2) 283-3397
34                   HANAR      Hanari Carnes                            Mario Pontes                   Accounting Manager             Rua do Paço, 67                                              Rio de Janeiro  RJ              05454-876  Brazil          (21) 555-0091            (21) 555-8765
35                   HILAA      HILARION-Abastos                         Carlos Hernández               Sales Representative           Carrera 22 con Ave. Carlos Soublette #8-35                   San Cristóbal   Táchira         5022       Venezuela       (5) 555-1340             (5) 555-1948
36                   HUNGC      Hungry Coyote Import Store               Yoshi Latimer                  Sales Representative           City Center Plaza 516 Main St.                               Elgin           OR              97827      USA             (503) 555-6874           (503) 555-2376
37                   HUNGO      Hungry Owl All-Night Grocers             Patricia McKenna               Sales Associate                8 Johnstown Road                                             Cork            Co. Cork        NULL       Ireland         2967 542                 2967 3333
38                   ISLAT      Island Trading                           Helen Bennett                  Marketing Manager              Garden House Crowther Way                                    Cowes           Isle of Wight   PO31 7PJ   UK              (198) 555-8888           NULL
39                   KOENE      Königlich Essen                          Philip Cramer                  Sales Associate                Maubelstr. 90                                                Brandenburg     NULL            14776      Germany         0555-09876               NULL
40                   LACOR      La corne d'abondance                     Daniel Tonini                  Sales Representative           67, avenue de l'Europe                                       Versailles      NULL            78000      France          30.59.84.10              30.59.85.11
41                   LAMAI      La maison d'Asie                         Annette Roulet                 Sales Manager                  1 rue Alsace-Lorraine                                        Toulouse        NULL            31000      France          61.77.61.10              61.77.61.11
42                   LAUGB      Laughing Bacchus Wine Cellars            Yoshi Tannamuri                Marketing Assistant            1900 Oak St.                                                 Vancouver       BC              V3F 2K1    Canada          (604) 555-3392           (604) 555-7293
43                   LAZYK      Lazy K Kountry Store                     John Steel                     Marketing Manager              12 Orchestra Terrace                                         Walla Walla     WA              99362      USA             (509) 555-7969           (509) 555-6221
44                   LEHMS      Lehmanns Marktstand                      Renate Messner                 Sales Representative           Magazinweg 7                                                 Frankfurt a.M.  NULL            60528      Germany         069-0245984              069-0245874
45                   LETSS      Let's Stop N Shop                        Jaime Yorres                   Owner                          87 Polk St. Suite 5                                          San Francisco   CA              94117      USA             (415) 555-5938           NULL
46                   LILAS      LILA-Supermercado                        Carlos González                Accounting Manager             Carrera 52 con Ave. Bolívar #65-98 Llano Largo               Barquisimeto    Lara            3508       Venezuela       (9) 331-6954             (9) 331-7256
47                   LINOD      LINO-Delicateses                         Felipe Izquierdo               Owner                          Ave. 5 de Mayo Porlamar                                      I. de Margarita Nueva Esparta   4980       Venezuela       (8) 34-56-12             (8) 34-93-93
48                   LONEP      Lonesome Pine Restaurant                 Fran Wilson                    Sales Manager                  89 Chiaroscuro Rd.                                           Portland        OR              97219      USA             (503) 555-9573           (503) 555-9646
49                   MAGAA      Magazzini Alimentari Riuniti             Giovanni Rovelli               Marketing Manager              Via Ludovico il Moro 22                                      Bergamo         NULL            24100      Italy           035-640230               035-640231
50                   MAISD      Maison Dewey                             Catherine Dewey                Sales Agent                    Rue Joseph-Bens 532                                          Bruxelles       NULL            B-1180     Belgium         (02) 201 24 67           (02) 201 24 68
51                   MEREP      Mère Paillarde                           Jean Fresnière                 Marketing Assistant            43 rue St. Laurent                                           Montréal        Québec          H1J 1C3    Canada          (514) 555-8054           (514) 555-8055
52                   MORGK      Morgenstern Gesundkost                   Alexander Feuer                Marketing Assistant            Heerstr. 22                                                  Leipzig         NULL            04179      Germany         0342-023176              NULL
53                   NORTS      North/South                              Simon Crowther                 Sales Associate                South House 300 Queensbridge                                 London          NULL            SW7 1RZ    UK              (171) 555-7733           (171) 555-2530
54                   OCEAN      Océano Atlántico Ltda.                   Yvonne Moncada                 Sales Agent                    Ing. Gustavo Moncada 8585 Piso 20-A                          Buenos Aires    NULL            1010       Argentina       (1) 135-5333             (1) 135-5535
55                   OLDWO      Old World Delicatessen                   Rene Phillips                  Sales Representative           2743 Bering St.                                              Anchorage       AK              99508      USA             (907) 555-7584           (907) 555-2880
56                   OTTIK      Ottilies Käseladen                       Henriette Pfalzheim            Owner                          Mehrheimerstr. 369                                           Köln            NULL            50739      Germany         0221-0644327             0221-0765721
57                   PARIS      Paris spécialités                        Marie Bertrand                 Owner                          265, boulevard Charonne                                      Paris           NULL            75012      France          (1) 42.34.22.66          (1) 42.34.22.77
58                   PERIC      Pericles Comidas clásicas                Guillermo Fernández            Sales Representative           Calle Dr. Jorge Cash 321                                     México D.F.     NULL            05033      Mexico          (5) 552-3745             (5) 545-3745
59                   PICCO      Piccolo und mehr                         Georg Pipps                    Sales Manager                  Geislweg 14                                                  Salzburg        NULL            5020       Austria         6562-9722                6562-9723
60                   PRINI      Princesa Isabel Vinhos                   Isabel de Castro               Sales Representative           Estrada da saúde n. 58                                       Lisboa          NULL            1756       Portugal        (1) 356-5634             NULL
61                   QUEDE      Que Delícia                              Bernardo Batista               Accounting Manager             Rua da Panificadora, 12                                      Rio de Janeiro  RJ              02389-673  Brazil          (21) 555-4252            (21) 555-4545
62                   QUEEN      Queen Cozinha                            Lúcia Carvalho                 Marketing Assistant            Alameda dos Canàrios, 891                                    Sao Paulo       SP              05487-020  Brazil          (11) 555-1189            NULL
63                   QUICK      QUICK-Stop                               Horst Kloss                    Accounting Manager             Taucherstraße 10                                             Cunewalde       NULL            01307      Germany         0372-035188              NULL
64                   RANCH      Rancho grande                            Sergio Gutiérrez               Sales Representative           Av. del Libertador 900                                       Buenos Aires    NULL            1010       Argentina       (1) 123-5555             (1) 123-5556
65                   RATTC      Rattlesnake Canyon Grocery               Paula Wilson                   Assistant Sales Representative 2817 Milton Dr.                                              Albuquerque     NM              87110      USA             (505) 555-5939           (505) 555-3620
66                   REGGC      Reggiani Caseifici                       Maurizio Moroni                Sales Associate                Strada Provinciale 124                                       Reggio Emilia   NULL            42100      Italy           0522-556721              0522-556722
67                   RICAR      Ricardo Adocicados                       Janete Limeira                 Assistant Sales Agent          Av. Copacabana, 267                                          Rio de Janeiro  RJ              02389-890  Brazil          (21) 555-3412            NULL
68                   RICSU      Richter Supermarkt                       Michael Holz                   Sales Manager                  Grenzacherweg 237                                            Genève          NULL            1203       Switzerland     0897-034214              NULL
69                   ROMEY      Romero y tomillo                         Alejandra Camino               Accounting Manager             Gran Vía, 1                                                  Madrid          NULL            28001      Spain           (91) 745 6200            (91) 745 6210
70                   SANTG      Santé Gourmet                            Jonas Bergulfsen               Owner                          Erling Skakkes gate 78                                       Stavern         NULL            4110       Norway          07-98 92 35              07-98 92 47
71                   SAVEA      Save-a-lot Markets                       Jose Pavarotti                 Sales Representative           187 Suffolk Ln.                                              Boise           ID              83720      USA             (208) 555-8097           NULL
72                   SEVES      Seven Seas Imports                       Hari Kumar                     Sales Manager                  90 Wadhurst Rd.                                              London          NULL            OX15 4NB   UK              (171) 555-1717           (171) 555-5646
73                   SIMOB      Simons bistro                            Jytte Petersen                 Owner                          Vinbæltet 34                                                 Kobenhavn       NULL            1734       Denmark         31 12 34 56              31 13 35 57
74                   SPECD      Spécialités du monde                     Dominique Perrier              Marketing Manager              25, rue Lauriston                                            Paris           NULL            75016      France          (1) 47.55.60.10          (1) 47.55.60.20
75                   SPLIR      Split Rail Beer & Ale                    Art Braunschweiger             Sales Manager                  P.O. Box 555                                                 Lander          WY              82520      USA             (307) 555-4680           (307) 555-6525
76                   SUPRD      Suprêmes délices                         Pascale Cartrain               Accounting Manager             Boulevard Tirou, 255                                         Charleroi       NULL            B-6000     Belgium         (071) 23 67 22 20        (071) 23 67 22 21
77                   THEBI      The Big Cheese                           Liz Nixon                      Marketing Manager              89 Jefferson Way Suite 2                                     Portland        OR              97201      USA             (503) 555-3612           NULL
78                   THECR      The Cracker Box                          Liu Wong                       Marketing Assistant            55 Grizzly Peak Rd.                                          Butte           MT              59801      USA             (406) 555-5834           (406) 555-8083
79                   TOMSP      Toms Spezialitäten                       Karin Josephs                  Marketing Manager              Luisenstr. 48                                                Münster         NULL            44087      Germany         0251-031259              0251-035695
80                   TORTU      Tortuga Restaurante                      Miguel Angel Paolino           Owner                          Avda. Azteca 123                                             México D.F.     NULL            05033      Mexico          (5) 555-2933             NULL
81                   TRADH      Tradição Hipermercados                   Anabela Domingues              Sales Representative           Av. Inês de Castro, 414                                      Sao Paulo       SP              05634-030  Brazil          (11) 555-2167            (11) 555-2168
82                   TRAIH      Trail's Head Gourmet Provisioners        Helvetius Nagy                 Sales Associate                722 DaVinci Blvd.                                            Kirkland        WA              98034      USA             (206) 555-8257           (206) 555-2174
83                   VAFFE      Vaffeljernet                             Palle Ibsen                    Sales Manager                  Smagsloget 45                                                Århus           NULL            8200       Denmark         86 21 32 43              86 22 33 44
84                   VICTE      Victuailles en stock                     Mary Saveley                   Sales Agent                    2, rue du Commerce                                           Lyon            NULL            69004      France          78.32.54.86              78.32.54.87
85                   VINET      Vins et alcools Chevalier                Paul Henriot                   Accounting Manager             59 rue de l'Abbaye                                           Reims           NULL            51100      France          26.47.15.10              26.47.15.11
86                   WANDK      Die Wandernde Kuh                        Rita Müller                    Sales Representative           Adenauerallee 900                                            Stuttgart       NULL            70563      Germany         0711-020361              0711-035428
87                   WARTH      Wartian Herkku                           Pirkko Koskitalo               Accounting Manager             Torikatu 38                                                  Oulu            NULL            90110      Finland         981-443655               981-443655
88                   WELLI      Wellington Importadora                   Paula Parente                  Sales Manager                  Rua do Mercado, 12                                           Resende         SP              08737-363  Brazil          (14) 555-8122            NULL
89                   WHITC      White Clover Markets                     Karl Jablonski                 Owner                          305 - 14th Ave. S. Suite 3B                                  Seattle         WA              98128      USA             (206) 555-4112           (206) 555-4115
90                   WILMK      Wilman Kala                              Matti Karttunen                Owner/Marketing Assistant      Keskuskatu 45                                                Helsinki        NULL            21240      Finland         90-224 8858              90-224 8858
91                   WOLZA      Wolski  Zajazd                           Zbyszek Piestrzeniewicz        Owner                          ul. Filtrowa 68                                              Warszawa        NULL            01-012     Poland          (26) 642-7012            (26) 642-7012

(91 row(s) affected)

 

The row numbering will be done in the order mentioned by the ORDER BY clause of the OVER section. In the previous example, the table was getting sorted in ascending order of the value of column CustomerID and the numbering was done in that order.

 

Performing Paging using Row Numbers

Suppose I want to show this data in 20 items in a pag e. I can get this done by using this row numbers to page the query results. Check out the following query:

SELECT * FROM (SELECT  ROW_NUMBER() OVER (ORDER BY CustomerID ASC) AS Row, * FROM Customers)AS WithRowNumbers WHERE  Row >= 1 AND Row <= 20

It only returns the first 20 rows. We can use the WHERE clause section to get any subset of rows ( example: rows 20 – 50 ).

Row                  CustomerID CompanyName                              ContactName                    ContactTitle                   Address                                                      City            Region          PostalCode Country         Phone                    Fax
-------------------- ---------- ---------------------------------------- ------------------------------ ------------------------------ ------------------------------------------------------------ --------------- --------------- ---------- --------------- ------------------------ ------------------------
1                    ALFKI      Alfreds Futterkiste                      Maria Anders                   Sales Representative           Obere Str. 57                                                Berlin          NULL            12209      Germany         030-0074321              030-0076545
2                    ANATR      Ana Trujillo Emparedados y helados       Ana Trujillo                   Owner                          Avda. de la Constitución 2222                                México D.F.     NULL            05021      Mexico          (5) 555-4729             (5) 555-3745
3                    ANTON      Antonio Moreno Taquería                  Antonio Moreno                 Owner                          Mataderos  2312                                              México D.F.     NULL            05023      Mexico          (5) 555-3932             NULL
4                    AROUT      Around the Horn                          Thomas Hardy                   Sales Representative           120 Hanover Sq.                                              London          NULL            WA1 1DP    UK              (171) 555-7788           (171) 555-6750
5                    BERGS      Berglunds snabbköp                       Christina Berglund             Order Administrator            Berguvsvägen  8                                              Luleå           NULL            S-958 22   Sweden          0921-12 34 65            0921-12 34 67
6                    BLAUS      Blauer See Delikatessen                  Hanna Moos                     Sales Representative           Forsterstr. 57                                               Mannheim        NULL            68306      Germany         0621-08460               0621-08924
7                    BLONP      Blondesddsl père et fils                 Frédérique Citeaux             Marketing Manager              24, place Kléber                                             Strasbourg      NULL            67000      France          88.60.15.31              88.60.15.32
8                    BOLID      Bólido Comidas preparadas                Martín Sommer                  Owner                          C/ Araquil, 67                                               Madrid          NULL            28023      Spain           (91) 555 22 82           (91) 555 91 99
9                    BONAP      Bon app'                                 Laurence Lebihan               Owner                          12, rue des Bouchers                                         Marseille       NULL            13008      France          91.24.45.40              91.24.45.41
10                   BOTTM      Bottom-Dollar Markets                    Elizabeth Lincoln              Accounting Manager             23 Tsawassen Blvd.                                           Tsawassen       BC              T2F 8M4    Canada          (604) 555-4729           (604) 555-3745
11                   BSBEV      B's Beverages                            Victoria Ashworth              Sales Representative           Fauntleroy Circus                                            London          NULL            EC2 5NT    UK              (171) 555-1212           NULL
12                   CACTU      Cactus Comidas para llevar               Patricio Simpson               Sales Agent                    Cerrito 333                                                  Buenos Aires    NULL            1010       Argentina       (1) 135-5555             (1) 135-4892
13                   CENTC      Centro comercial Moctezuma               Francisco Chang                Marketing Manager              Sierras de Granada 9993                                      México D.F.     NULL            05022      Mexico          (5) 555-3392             (5) 555-7293
14                   CHOPS      Chop-suey Chinese                        Yang Wang                      Owner                          Hauptstr. 29                                                 Bern            NULL            3012       Switzerland     0452-076545              NULL
15                   COMMI      Comércio Mineiro                         Pedro Afonso                   Sales Associate                Av. dos Lusíadas, 23                                         Sao Paulo       SP              05432-043  Brazil          (11) 555-7647            NULL
16                   CONSH      Consolidated Holdings                    Elizabeth Brown                Sales Representative           Berkeley Gardens 12  Brewery                                 London          NULL            WX1 6LT    UK              (171) 555-2282           (171) 555-9199
17                   DRACD      Drachenblut Delikatessen                 Sven Ottlieb                   Order Administrator            Walserweg 21                                                 Aachen          NULL            52066      Germany         0241-039123              0241-059428
18                   DUMON      Du monde entier                          Janine Labrune                 Owner                          67, rue des Cinquante Otages                                 Nantes          NULL            44000      France          40.67.88.88              40.67.89.89
19                   EASTC      Eastern Connection                       Ann Devon                      Sales Agent                    35 King George                                               London          NULL            WX3 6FW    UK              (171) 555-0297           (171) 555-3373
20                   ERNSH      Ernst Handel                             Roland Mendel                  Sales Manager                  Kirchgasse 6                                                 Graz            NULL            8010       Austria         7675-3425                7675-3426

(20 row(s) affected)

Using this technique we can page the result of the SELECT query.

 

Code Sample

Now I shall demonstrate with a code sample.

screen


In this sample, I’ll use a GridView control and an SqlDataSource Control. But the SELECT query used in the SqlDataSource control will be paged according to the PageSize property of the GridView Control.

 

Check out the following code

Default.aspx

<%@ Page Language="C#" AutoEventWireup="true"  CodeFile="Default.aspx.cs" Inherits="_Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:GridView ID="GridView1" runat="server" DataSourceID="SqlDataSource1" AllowPaging="True">
            <PagerTemplate>
                <table style="width: 100%; height: 100%">
                    <tr>
                        <td style="width: 100%; text-align:center">
                            <asp:LinkButton ID="LinkButton1" runat="server" OnClick="LinkButton1_Click"><</asp:LinkButton>
                            &nbsp;<%# GridView1.PageIndex %>&nbsp;
                            <asp:LinkButton ID="LinkButton2" runat="server" OnClick="LinkButton2_Click">></asp:LinkButton>
                        </td>
                    </tr>
                </table>
            </PagerTemplate>
            <EmptyDataTemplate>
                No data found.
            </EmptyDataTemplate>
        </asp:GridView>
        &nbsp;</div>
        <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString %>" 
            SelectCommand="SELECT * FROM (SELECT  ROW_NUMBER() OVER (ORDER BY CustomerID ASC) AS Row, * FROM Customers)AS WithRowNumbers WHERE  Row > (@PageIndex-1 * @PageSize) AND Row <= ((@PageIndex * @PageSize)+@PageSize+1)">
            <SelectParameters>
                <asp:ControlParameter ControlID="GridView1" Name="PageIndex" PropertyName="PageIndex" Type="Int16" />
                <asp:ControlParameter ControlID="GridView1" Name="PageSize" PropertyName="PageSize" Type="Int16" />
            </SelectParameters>
        </asp:SqlDataSource>
    </form>
</body>
</html>

 

Explanations

The SELECT query used here is following:

SELECT * FROM (SELECT  ROW_NUMBER() OVER (ORDER BY CustomerID ASC) AS Row, * FROM Customers)AS WithRowNumbers WHERE  Row > (@PageIndex-1 * @PageSize) AND Row <= ((@PageIndex * @PageSize)+@PageSize+1)

Here the @PageIndex and @PageSize are Control Parameters. They represent the properties PageIndex and PageSize of the GridView control respectively. The formula used in the WHERE clause makes sure that only the rows appropriate for the current page of the GridView is retrieved instead of all the rows. This will improve the performance a bit as I don’t have to load the entire table data at once on the GridView control.

The default paging system in the GridView loads all the data in place then pages them. I’ve seen through experience that the approach shown in this example is much faster than the normal approach as it will not load the entire table data at once (in case of large tables there can be thousands of rows – so loading such volume of data at once will eat up performance).

Also note that, I have changed the PagerTemplate of the GridView control to modify the appearance. This is optional. You could go with the normal PagerTemplate.

The code behind file is following

Default.aspx.cs

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

public partial class _Default : System.Web.UI.Page 
{
    protected void Page_Load(object sender, EventArgs e)
    {

    }

    protected void LinkButton1_Click(object sender, EventArgs e)
    {
        GridView1.PageIndex--;
    }
    protected void LinkButton2_Click(object sender, EventArgs e)
    {
        GridView1.PageIndex++;
    }
}

 

Output Preview

screen2

Fig: GridView with PageSize 10 and PageIndex = 1 (Second page)

Conclusion

It is quite easy to perform paging in Transact-SQL by using the ROW_NUMBER function. The query will be like the following

SELECT * FROM (SELECT  ROW_NUMBER() OVER (ORDER BY [COLUMNNAME] ASC) AS Row, * FROM [TABLENAME])AS WithRowNumbers WHERE  Row >= StartingIndex and Row =< EndIndex

 

That’s it !! Hope you have enjoyed it. Good Luck ! 

 

Download Solution - QueryPagingDemo.zip

 

Please rate my post if you like it.

Regards,

Sheikh Ali Arman

Creating DataBound Custom Controls

Hello and welcome to my weblog.

In this blog I shall demonstrate how to develop a Custom DataBound Web Control.

Suppose you are trying to get some special features from a control. Your desired features are not available in the default set of controls in Visual Studio toolbar. What do you do?

There are several options - developing a custom web control is one of them. And making your custom control DataBindingcapable is also a good idea as you can easily populate it with data with DataBinding.

The control I’m going to make in this demo is a simple DataBound Table. It can be DataBound to all types of data sources including SqlDataSource Control, DataTable, DataSet, ArrayList and different types of lists etc. 

 

DataBoundTable.cs

   1: using System;
   2: using System.Drawing;
   3: using System.Drawing.Design;
   4: using System.Collections;
   5: using System.Collections.Generic;
   6: using System.ComponentModel;
   7: using System.Security.Permissions;
   8: using System.Web;
   9: using System.Web.UI;
  10: using System.Web.UI.WebControls;
  11:  
  12: namespace CustomDataBoundControls
  13: {
  14:     [
  15:     AspNetHostingPermission(SecurityAction.Demand, Level = AspNetHostingPermissionLevel.Minimal),
  16:     AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal),
  17:     DefaultProperty("DataFields"),
  18:     ParseChildren(true,"DataFields"),
  19:     ToolboxData("<{0}:DataBoundTable runat=\"server\" ShowHeaders=\"true\" > </{0}:DataBoundTable>"),
  20:     ToolboxBitmap(typeof(DataBoundTable), "logo")
  21:     ]
  22:     public class DataBoundTable : DataBoundControl
  23:     {
  24:         private List<DataField> dataFields = new List<DataField>();
  25:  
  26:         // This property keeps the DataFields. DataFields are the fields 
  27:         // shown by this custom table. If no DataField is defined, the control 
  28:         // shows all the fields available in the given DataSource.
  29:         [
  30:         System.ComponentModel.Browsable(true),   
  31:         System.ComponentModel.Category("Data"), 
  32:         DesignerSerializationVisibility(DesignerSerializationVisibility.Content), 
  33:         Editor(typeof(DataFieldCollectionEditor), typeof(UITypeEditor)),
  34:         PersistenceMode(PersistenceMode.InnerDefaultProperty) 
  35:         ]
  36:         public List<DataField> DataFields
  37:         {
  38:             get { return dataFields; }
  39:             set { dataFields = value; }
  40:         }
  41:  
  42:         // This property decides whether the headers should be shown or not.
  43:         [System.ComponentModel.Browsable(true),
  44:         System.ComponentModel.Category("Appearance"),
  45:         DesignerSerializationVisibility(DesignerSerializationVisibility.Visible),
  46:         PersistenceMode(PersistenceMode.Attribute)
  47:         ]
  48:         public bool ShowHeaders
  49:         {
  50:             get { return _showHeaders; }
  51:             set { _showHeaders = value; }
  52:         }
  53:         private bool _showHeaders;
  54:                 
  55:  
  56:         protected override void PerformSelect()
  57:         {
  58:             // Call OnDataBinding here if bound to a data source using the
  59:             // DataSource property (instead of a DataSourceID), because the
  60:             // databinding statement is evaluated before the call to GetData.       
  61:             if (!IsBoundUsingDataSourceID)
  62:             {
  63:                 this.OnDataBinding(EventArgs.Empty);
  64:             }
  65:  
  66:             // The GetData method retrieves the DataSourceView object from  
  67:             // the IDataSource associated with the data-bound control.            
  68:             GetData().Select(CreateDataSourceSelectArguments(),
  69:                 this.OnDataSourceViewSelectCallback);
  70:  
  71:             // The PerformDataBinding method has completed.
  72:             RequiresDataBinding = false;
  73:             MarkAsDataBound();
  74:  
  75:             // Raise the DataBound event.
  76:             OnDataBound(EventArgs.Empty);
  77:         }
  78:  
  79:         private void OnDataSourceViewSelectCallback(IEnumerable retrievedData)
  80:         {
  81:             // Call OnDataBinding only if it has not already been 
  82:             // called in the PerformSelect method.
  83:             if (IsBoundUsingDataSourceID)
  84:             {
  85:                 OnDataBinding(EventArgs.Empty);
  86:             }
  87:             // The PerformDataBinding method binds the data in the  
  88:             // retrievedData collection to elements of the data-bound control.
  89:             PerformDataBinding(retrievedData);
  90:         }
  91:  
  92:         protected override void PerformDataBinding(IEnumerable retrievedData)
  93:         {
  94:             base.PerformDataBinding(retrievedData);
  95:  
  96:             // Verify data exists. retrievedData variable will hold all the
  97:             // rows retrieved from the data source.
  98:             if (retrievedData != null)
  99:             {
 100:                 // Creating the table which shows the data.
 101:                 // This is the main appearance of this custom control.
 102:                 Table tbl = new Table();
 103:  
 104:                 if (ShowHeaders)
 105:                 {
 106:                     // creating the header row of the table if ShowHeader is true
 107:                     TableRow headerRow = new TableRow();
 108:                     TableCell headerCell;
 109:                     tbl.Rows.Add(headerRow);
 110:  
 111:                     // if DataFields are mentioned (i.e. the developer has configured 
 112:                     // which columns to be shown) then using the Key property as the 
 113:                     // header of those chosen columns
 114:                     if (DataFields.Count > 0)
 115:                     {
 116:                         foreach (DataField field in DataFields)
 117:                         {
 118:                             headerCell = new TableCell();
 119:                             headerCell.Text = field.Header;
 120:                             headerCell.Font.Bold = true;
 121:                             headerRow.Cells.Add(headerCell);
 122:                             tbl.Rows.Add(headerRow);
 123:                         }
 124:                     }
 125:  
 126:                     // DataFields are not mentioned. Showing header for all columns
 127:                     // available in DataSource. Using the value of Key property as 
 128:                     // the header.
 129:                     else
 130:                     {
 131:                         IEnumerator myEnumerator = retrievedData.GetEnumerator();
 132:                         myEnumerator.MoveNext();
 133:  
 134:                         PropertyDescriptorCollection props =
 135:                                 TypeDescriptor.GetProperties(myEnumerator.Current);
 136:  
 137:                         for (int i = 0; i < props.Count; i++)
 138:                         {
 139:                             headerCell = new TableCell();
 140:                             headerCell.Text = props[i].Name;
 141:                             headerCell.Font.Bold = true;
 142:                             headerRow.Cells.Add(headerCell);
 143:                         }
 144:                     }
 145:                 }
 146:  
 147:  
 148:                 // creating the rows containing data...
 149:  
 150:                 TableRow row;
 151:                 TableCell cell;
 152:                 string dataStr = String.Empty;
 153:  
 154:                 foreach (object dataItem in retrievedData)
 155:                 {
 156:                     row = new TableRow();
 157:                     tbl.Rows.Add(row);
 158:  
 159:                     // if DataFields are mentioned (i.e. the developer has configured 
 160:                     // which columns to be shown) then using the Value property as the 
 161:                     // Value of those chosen columns
 162:                     if( DataFields.Count > 0)
 163:                     {
 164:                         foreach (DataField field in DataFields)
 165:                         {
 166:                             // field.FieldName will provide the column name
 167:                             // using it to get the data of that column for the current row.
 168:                             dataStr = DataBinder.GetPropertyValue(dataItem,
 169:                                 field.FieldName, null);
 170:                              
 171:                             cell = new TableCell();
 172:                             cell.Text = dataStr;
 173:                             row.Cells.Add(cell);
 174:                         }
 175:                     }
 176:  
 177:                     // DataFields are not mentioned. Showing value for all columns
 178:                     // available in DataSource. Using the Value property as 
 179:                     // the value.
 180:                     else
 181:                     {
 182:                         PropertyDescriptorCollection props =
 183:                                 TypeDescriptor.GetProperties(dataItem);
 184:                         for (int i = 0; i < props.Count; i++)
 185:                         {
 186:                             if (props[i].GetValue(dataItem) != null)
 187:                             {
 188:                                 dataStr = props[i].GetValue(dataItem).ToString();
 189:                                 cell = new TableCell();
 190:                                 cell.Text = dataStr;
 191:                                 row.Cells.Add(cell);
 192:                             }
 193:                         }
 194:                     }
 195:                 }
 196:  
 197:                 this.Controls.Add(tbl);
 198:             }
 199:         }
 200:     }
 201: }

 

Some Explanations: ( for code explanations view the code comments)


To make a databound control we have to implement the abstract class DataBoundControl so that our control gets the DataBinding features.

   1: public class DataBoundTable : DataBoundControl

Next, I have declared a variable called DataFields which will hold the fields I want to show in my DataBound table.

   1: public List<DataField> DataFields
   2: {
   3:     get { return dataFields; }
   4:     set { dataFields = value; }
   5: }

I’ve also declared another variable named ShowHeaders which is a boolean variable indicating whether the headers should be shown.

   1: public bool ShowHeaders
   2: {
   3:     get { return _showHeaders; }
   4:     set { _showHeaders = value; }
   5: }
   6: private bool _showHeaders;

Now lets look at the Attributes applied onto both of the Properties (DataFields and ShowHeaders).

   1: [System.ComponentModel.Browsable(true)]
   2: [System.ComponentModel.Category("Data")]

These attribute indicates that the property can be viewed/edited by the property window of Visual Studio and under the category Data.

   1: DesignerSerializationVisibility(DesignerSerializationVisibility.Content)

DesignerSerializationVisibilityAttribute: Setting the Content parameter specifies that a visual designer should serialize the contents of the property. In the example, the property contains DataField objects.

   1: [PersistenceMode(PersistenceMode.InnerDefaultProperty)]
   2: [PersistenceMode(PersistenceMode.Attribute)]

PersistenceModeAttribute:   Passing the PersistenceMode.InnerDefaultProperty parameter specifies that a visual designer should persist the property to which the attribute is applied as an inner default property. This means that a visual designer persists the property within the control's tags. The attribute can be applied to only one property, because only one property can be persisted within the control's tags. The property value is not wrapped in a special tag. PersistenceMode.Attribute indicates that the property should be persisted as an attribute of the control.

   1: [ToolboxData("<{0}:DataBoundTable runat=\"server\" ShowHeaders=\"true\" > </{0}:DataBoundTable>")]
   2: [ToolboxBitmap(typeof(DataBoundTable), "logo")]

ToolboxData configures the default markup that is created once the control is drag-dropped on the design view of Visual Studio. {0} is a placeholder which will contain the TagPrefix of the control mentioned in the Register directive of Default.aspx page.

   1: <%@ Register Assembly="CustomDataBoundControls" Namespace="CustomDataBoundControls" TagPrefix="cc1" %>

 

What’s next ??

You probably have noticed that the DataFields property (which holds the field names and headers) is a generic List (a collection class). If we use Visual Studio designer to change the items (add-edit-remove) in it, the changes will not be preserved by default. To make the changes preserved we have to take some extra steps.

Check the following codes

DataField.cs

   1: // DataField.cs
   2: // The type of the items in the DataFields collection property 
   3: // in DataBoundTable.
   4:  
   5: using System;
   6: using System.Collections;
   7: using System.ComponentModel;
   8: using System.Web.UI;
   9:  
  10: namespace CustomDataBoundControls
  11: {
  12:     [
  13:     TypeConverter(typeof(ExpandableObjectConverter))
  14:     ]
  15:     public class DataField
  16:     {
  17:         private string _header;
  18:         private string _fieldName;
  19:         
  20:         public DataField()
  21:             : this(String.Empty, String.Empty)
  22:         {
  23:         }
  24:  
  25:         public DataField(string header, string fieldName)
  26:         {
  27:             _header = header;
  28:             _fieldName = fieldName;
  29:         }
  30:  
  31:         [
  32:         Category("Behavior"),
  33:         DefaultValue(""),
  34:         Description("Field/Column Name"),
  35:         NotifyParentProperty(true),
  36:         ]
  37:         public String FieldName
  38:         {
  39:             get
  40:             {
  41:                 return _fieldName;
  42:             }
  43:             set
  44:             {
  45:                 _fieldName = value;
  46:             }
  47:         }
  48:  
  49:         [
  50:         Category("Behavior"),
  51:         DefaultValue(""),
  52:         Description("Header Text"),
  53:         NotifyParentProperty(true)
  54:         ]
  55:         public String Header
  56:         {
  57:             get
  58:             {
  59:                 return _header;
  60:             }
  61:             set
  62:             {
  63:                 _header = value;
  64:             }
  65:         }
  66:     }
  67: }

DataFieldCollectionEditor.cs

   1: using System;
   2: using System.ComponentModel;
   3: using System.ComponentModel.Design;
   4: using System.Reflection;
   5:  
   6: namespace CustomDataBoundControls
   7: {
   8:     public class DataFieldCollectionEditor : CollectionEditor
   9:     {
  10:         public DataFieldCollectionEditor(Type type)
  11:             : base(type)
  12:         {
  13:         }
  14:  
  15:         protected override bool CanSelectMultipleInstances()
  16:         {
  17:             return false;
  18:         }
  19:  
  20:         protected override Type CreateCollectionItemType()
  21:         {
  22:             return typeof(DataField);
  23:         }
  24:     }
  25: }
  26:  
 

The DataBoundTable control associates a collection editor with the Contacts collection property using the EditorAttribute, as in the following example:

[Editor(typeof(DataFieldCollectionEditor), typeof(UITypeEditor))]

Associating a collection editor with the property enables the property browser in a visual designer to open a collection editor for adding DataField items. This is similar to the user interface (UI) for editing the Items property of the DropDownList or ListBox controls. The custom collection editor used by DataBoundTable, DataFieldCollectionEditor, is given in DataFieldCollectionEditor.cs file.

 

abc

 

The DataBoundTable control does not implement state management for the collection property. The collection items are assumed to be added declaratively in the page or, if created in code, they must be recreated on postback. In a production-quality control, you would implement state management.

 

How to use it on Page

Lets look at the Default.aspx page

   1: <%@ Page Language="C#" AutoEventWireup="true"  CodeFile="Default.aspx.cs" Inherits="_Default" %>
   2:  
   3: <%@ Register Assembly="CustomDataBoundControls" Namespace="CustomDataBoundControls" TagPrefix="cc1" %>
   4:  
   5: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
   6:  
   7: <html xmlns="http://www.w3.org/1999/xhtml" >
   8: <head runat="server">
   9:     <title>Untitled Page</title>
  10: </head>
  11: <body>
  12:     <form id="form1" runat="server">
  13:     <div>
  14:         <cc1:DataBoundTable ID="DataBoundTable1" runat="server" ShowHeaders="true">
  15:         </cc1:DataBoundTable>
  16:         <br />
  17:         <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString %>" SelectCommand="SELECT * FROM [Customers] ORDER BY [CustomerID]"></asp:SqlDataSource>
  18:         <br />
  19:         <br />
  20:     
  21:     </div>
  22:     </form>
  23: </body>
  24: </html>

 

I created an SqlDataSource Control and used it as a DataSource for the DataBoundTable Control. I could also use DataSet, DataTable or even a List to DataBind my custom control.

 

snapshot

 

Output Preview

abcde


Here you go !! A cool DataBound Table. Use the technique shown here to create any DataBound Control you want.


Enjoy !!! 

 

Download Solution - DataBindingDemo.zip

 

Please rate my post if you like it.

Regards,

Sheikh Ali Arman

Symmetric Encryption using Rijndael Algorithm
While working with data we often need to secure it with some sort of encryption. While I was at school, our math teacher showed us a simple encryption technique known as Caesar Cypher . Useful it may be, but modern software development calls for better...