Click here to Skip to main content
Click here to Skip to main content

Tagged as

N-Tier: Begginer's guide in designing their application

, 25 Dec 2011 CPOL
Rate this:
Please Sign up or sign in to vote.
N-Tier
A great way to design your own application is to use the N-tier architecture.
 
This is just a simple tip that I will share and it is for you to check out.
 
Note: The following layers are exposed as different projects under one solution.
 
Object Layer: Create a class with properties:
public class Person
{
   public string Firstname {get;set;}
   public string Lastname {get;set;}
   public int Age {get;set;}
}
Data Access Layer: The layer that interacts with database:
 
public sealed class PersonDAL
{
   Person person = new Person();
   public static int GetAge(string firstname, string lastname)
   {
      try
      {
         SQLConnection sqlcon = new SQLConnection(ConfigurationManager
                                                      .ConnectionStrings["myDB"]
                                                      .ConnectionString);
         SQLCommand sqlcmd = new SQLCommand("SELECT age FROM Person_tb WHERE
                               firstname=@firstname AND lastname=@lastname",
                               sqlconn);
         sqlcmd.CommandType = CommandType.CommandText;
         sqlcmd.Parameters.AddWithValue("@firstname", firstname);
         sqlcmd.Parameters.AddWithValue("@lastname", lastname);
         sqlcon.Open();
         int retval = (int)sqlcmd.ExecuteScalar();
      }
      catch(Exception ex)
      {
         //Log ex
      }
      finally
      { 
         sqlcmd.Dispose();
         sqlcon.Close();
         sqlcon = null;
      }
   }
}
Business Logic Layer: The layer that serves as bridge for DAL and Application Layer:
 
public sealed class PersonBLL
{
   public static int GetAge(string firstname, string lastname)
   {
      return PersonDAL.GetAge(firstname, lastname);
   }
}
Application/Presentation Layer: The layer where users input data:
 
Person person = new Person();
person.Firstname = "Eduard";
person.Lastname = "Lu";
 
string firstname = person.Firstname;
string lastname = person.Lastname;
 
txtAge.Text = PersonBLL.GetAge(firstname, lastname).ToString();
 
There are still a lot of ways to optimize this one. You can add more layers which your application might be needing. For example, add a Utilities Layer wherein you can place your configuration/settings and your error/transaction logger. In my example, you can create a function that will return the connection string for your application to communicate with your database server.
 
Also, creating stored procedure is better than using command text. In my example, I used command text just to show you my query.
 
Message me if you have concerns. Smile | :)

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

Share

About the Author


Comments and Discussions

 
General[My vote of 1] [My vote of 1] PinmemberCelPlusPlus12-Sep-14 8:06 
QuestionThose aren't tiers PinmemberPIEBALDconsult5-Apr-12 6:33 
GeneralRe: thanks Reiss PinmemberEduard Lu28-Nov-11 23:00 
GeneralRe: Good article btw, now voted PinmemberReiss28-Nov-11 22:54 
GeneralWe use this model exclusively, as highly detailed on Spaanja... PinmemberEngleA20-Dec-11 6:06 
GeneralMVP! MVP! MVP! I just got going on my next customer's projec... Pinmemberchuckamus_prime20-Dec-11 4:22 
GeneralReason for my vote of 1 Short summary of the N-tier approach... PinmemberDavidOwen19-Dec-11 19:59 
GeneralI wonder why the presentation layer should know about the bu... Pinmemberbradut8-Dec-11 8:46 
I wonder why the presentation layer should know about the business layer in
txtAge.Text = PersonBLL.GetAge(firstname, lastname).ToString();
I thought that the object itself should communicate with the BLL, like:
txtAge.Text = person.Age;
so that the UI would be completely agnostic of how things are done.
GeneralReason for my vote of 5: Its precise and concise, should rea... PinmemberUday P.Singh5-Dec-11 21:43 
GeneralRe: thanks! :) PinmemberEduard Lu5-Dec-11 21:45 
GeneralReason for my vote of 5 A practical example I needed to unde... PinmemberMarius Coetzee5-Dec-11 18:40 
GeneralRe: thanks! PinmemberEduard Lu5-Dec-11 21:31 
GeneralReason for my vote of 5 exactly what i am looking for! thank... PinmemberAja wakim1-Dec-11 17:38 
GeneralRe: thanks aja PinmemberEduard Lu1-Dec-11 17:44 
GeneralOne question, what's the reason to implementing a BLL? You c... Pinmembermonolicciolo30-Nov-11 22:38 
GeneralRe: you can put your validation inside the BLL before returning ... PinmemberEduard Lu30-Nov-11 22:47 
GeneralReason for my vote of 3 ok PinmemberGanesanSenthilvel30-Nov-11 16:20 
GeneralReason for my vote of 5 Very nice... incredibly rudimentary,... PinmemberBrianBissell30-Nov-11 7:54 
GeneralRe: Thanks brian PinmemberEduard Lu30-Nov-11 15:16 
GeneralReason for my vote of 1 :) PinmemberHorváth Aladár30-Nov-11 0:05 
GeneralRe: FYI. 1 is bad, 5 is good. Considering that your comment is a... PinmemberMarcus Kramer30-Nov-11 4:45 
GeneralRe: :) PinmemberEduard Lu30-Nov-11 15:15 
GeneralThat is really a a nice to understand example.could you plea... PinmemberYashar_Khan29-Nov-11 20:39 
GeneralReason for my vote of 5 5 from me as well. PinmemberMarcus Kramer29-Nov-11 11:03 
GeneralRe: thanks Marcus PinmemberEduard Lu29-Nov-11 20:57 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Terms of Use | Mobile
Web01 | 2.8.141220.1 | Last Updated 25 Dec 2011
Article Copyright 2011 by Eduard Lu
Everything else Copyright © CodeProject, 1999-2014
Layout: fixed | fluid