Practical Demo

Practical Demonstration For Dotnet

My New Blog

Friends and my dudes.. I have altered my blog and change its address to http://www.dotnetandwp7.blogspot.com so please go to that page and refer. In that page i'm going to post Windows phone 7 application development Articles also.. Have a Nice Day....

Saturday, November 27, 2010

Working with LINQ TO SQL Example

LINQ to SQL Example:
1) In Microsoft Visualstudio2008, Select FileàNew àProject and select ASP.NET Web Application and give name as LINQQQ.
2) In Default.aspx page design the webpage as given below.
3) Create the database named “linqsamples” and create the table employee with the required field given below.
    
Turn off the Identity Specification to “NO”.
4) After creating the Database next we have to create dbml in our application. To do this , following the steps given below.
     a) choose Project menuà Add New Item and select “LINQ to SQL Classes” and give name as employee.dbml.
     b) In Solution Explorer double click the “employee.dbml” and in that file drag oue employee table and drop it.
    

c) In Default.aspx.cs, type the following code:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace LINQQQ
{
    public partial class _Default : System.Web.UI.Page
    {
       
         DAL dal = new DAL();       
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!Page.IsPostBack)
            {
                BindGrid();
            }
        }

        protected void btnSave_Click(object sender, EventArgs e)
        {
            employee emp = new employee();

            emp.ID = int.Parse( txtID.Text);
            emp.name = txtName.Text;
            emp.description = txtDesc.Text;
            dal.SaveEmployee(emp);
            BindGrid();
        }

        private void BindGrid()
        {
            gvEmployees.DataSource = dal.GetAllEmployees();
            gvEmployees.DataBind();
        }

        protected void gvEmployees_RowCommand(object sender, GridViewCommandEventArgs e)
        {
            hdnID.Value = e.CommandArgument.ToString();
            if (e.CommandName == "EditEmployee")
            {
                //employee emp = new employee();
               employee emp = GetEmployee(Convert.ToInt32(hdnID.Value));
                txtName.Text = emp.name;
                txtDesc.Text = emp.description;
                btnSave.Visible = false;
                btnUpdate.Visible = true;
            }
            else if (e.CommandName == "DeleteEmployee")
            {
                dal.DeleteEmployee(Convert.ToInt32(hdnID.Value));
                BindGrid();
            }
        }

      
       private employee GetEmployee(int ID)
        {
           employee emp = dal.GetEmployees(ID);
            return emp;
        }
       

        private void ClearScreen()
        {
            txtName.Text = string.Empty;
            txtDesc.Text = string.Empty;
        }

       protected void btnUpdate_Click(object sender, EventArgs e)
        {
            employee emp = new employee();
            emp.ID = Convert.ToInt32(hdnID.Value);
            emp.name = txtName.Text;
            emp.description = txtDesc.Text;
            dal.UpdateEmployee(emp);
            BindGrid();
        }
    }
   }

d) Now you have to create a new class file named DAL.cs.
   Choose ProjectàAddNewItem and select class file and give name as “DAL.cs”
“DAL.cs” class file is mainly used to create the methods for Inserting, Updating and Deleting records in a nice manner.
    BY way of creating object to the class we have to access the methods in the class.
   Ex:
         DAL dal=new DAL();

Now in DAL.cs Class file type the following code:

DAL.cs:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace LINQQQ
{
    public class DAL
    {
        employeeDataContext context = new employeeDataContext();
        public List<employee> GetAllEmployees()
        {
            Open();
            var Res = context.employees.ToList();
            Close();
            return Res;
        }
        private void Open()
        {
            context.Connection.Open();
        }

        private void Close()
        {
            context.Connection.Close();
        }
        public List<employee> GetEmployees(string Search)
        {
            Open();
            var Res = (from emp in context.employees
                       where emp.name.Contains(Search)
                       select emp).ToList();
            Close();
            return Res;
        }
        public void SaveEmployee(employee emp)
        {
            Open();
            this.context.employees.InsertOnSubmit(emp);
            this.context.SubmitChanges();
            Close();
        }
        public void UpdateEmployee(employee emp)
        {
            Open();
            var employee = (from em in this.context.employees
                            where em.ID == emp.ID
                            select em).First();
            employee.name = emp.name;
            employee.description = emp.description;
            this.context.SubmitChanges();
            Close();
        }
        public void DeleteEmployee(int ID)
        {
            Open();
            var emp = (from em in this.context.employees
                       where em.ID == ID
                       select em).First();
            this.context.employees.DeleteOnSubmit(emp);
            this.context.SubmitChanges();
            Close();
        }
        public employee GetEmployees(int ID)
        {
            Open();
            var emp = (from em in this.context.employees
                       where em.ID == ID
                       select em).First();
            Close();
            return emp;

        }
    }
}

   e) Now run the project LINQ works perfect..
       All the Best... J

LINQ TO Object Sample

LINQ:
          LINQ stands for “Language Integrated Query”.
Different datastores has got different query languages. Microsoft’s idea is providing one query language syntax to all the datastors to make developer job easier.
This lead to invention of LINQ with .NET3.5
LINQ is a concept of performing queries based on language syntax.

LINQ syntax:
           var res= from variablename in source
                           where condition
                           group by...
                           order by...
                           select variablename;

     source can be database, object, xml document.

LINQ can be classified into 3 types:

   1) LINQ to Object.
   2) LINQ to SQL.
   3) LINQ to XML.

LINQ to object:
           Applying linq query expression to object is called “Linq to object”.
 Ex:
      Int[]a={2,5,6,7,1,3};
//Display number>=5
      var res = from aa in a
                     where aa>=5
                     order by aa descending
                     select aa;
LINQ Samples: Restriction Operators

Where - Simple 1
This sample uses where to find all elements of an array less than 5.

public void Linq1()
{
    int[] numbers = { 5, 4, 1, 3, 9, 8, 6, 7, 2, 0 };

    var lowNums =
        from n in numbers
        where n < 5
        select n;

    Console.WriteLine("Numbers < 5:");
    foreach (var x in lowNums)
    {
        Console.WriteLine(x);
    }
}

Result
Numbers < 5:
4
1
3
2
0
Where - Indexed
This sample demonstrates an indexed Where clause that returns digits whose name is shorter than their value.
public void Linq5()
{
    string[] digits = { "zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine" };

    var shortDigits = digits.Where((digit, index) => digit.Length < index);

    Console.WriteLine("Short digits:");
    foreach (var d in shortDigits)
    {
        Console.WriteLine("The word {0} is shorter than its value.", d);
    }
}

Result
Short digits:
The word five is shorter than its value.
The word six is shorter than its value.
The word seven is shorter than its value.
The word eight is shorter than its value.
The word nine is shorter than its value.

Introduction to DotNet ...

.NET framework is an essential component of the windows operating system and helps create applications by integrating different programming languages, such as Visual C#, Visual Basic, Visual C++, and so on. .NET Framework consists of a virtual execution syatem called the common language runtime(CLR) and a set of class libraries. CLR is a Microsoft product of the Common Language Infrastructure(CLI), which is an industrial standard and a basis for creating execution and development environmentss in which languages and libraries work together. Microsoft introduced .NET to bridge the gap and ensure interoperability between application created in different languages. .NET framework is used to integrate the business logic of an application implemented in different programming languages and services. Consequently, it induces significant improvements in code reusability, code specialization, resource management, development of applications in multiple programming languages, security, deployment, and administration of programs developed in multiple programming languages..

Why .NET?

Why .NET? Mainly .NET is the competitor for JAVA. . Its an environment or platform. It contains collection of services for application development and application execution. It supports different type of applications development. ex: CUI, GUI, console, web based,mobile applications Main thing is .NET is network & Internet based application development.It provides a good development environment. ex: Drag and Drop design - IntelliSense features - Syntax highlighting and auto-syntax checking - Excellent debugging tools - Integration with version control software such as Visual Source Safe (VSS) - Easy project management

Evaluation of .NET:

Around 1995, Java was gaining popularity because of its platform-independent approach and Sun Microsyatem's open source policy. Later in 2002, Sun Microsystems released the enterprise edition of Java. ie., Java 2 Enterprise edition(J2EE), which is a Java Platform to develop and execute distributed Java Applications based on the N-tier architecture. The advent of J2EE eventually led to the decline of, Microsoft's Market share. Consequently, Microsoft started a project called NEXT GENERATION WINDOWS SERVICE(NGWS) to regain the market share . It tooks more than three years to develop the product, Which is Known as .NET. Microsoft released the first version of .NET with the name .NET Framework 1.0 on february 13,2002, along with the Visual studio .NET 2002 integrated development environment(IDE). .NET's Second revised version took nearly a year to release; and it was known as .NET framework 1.1 Microsoft Visual studio .NET, bettre known as Visual studio .NET2003, was also a part of the second release. The next version of .NET framework, .NET Framework 2.0, was released with Visual studio .NET 2005 on november 07,2005. .NET framework 3.0 formerly called WinFX, was released on novenber 06,2006. Finally the latest version of .NET framework, known as .NET framework 3.5, was released with Visual studio .NET2008 on november 19,2007.

Flavors of .NET:


Contrary to general belief .NET is not a single technology. Rather it is a set of
technologies that work together seamlessly to solve your business problems. The
following sections will give you insight into various flavors and tools of .NET and what kind of applications you can develop.
• What type of applications can I develop?
When you hear the name .NET, it gives a feeling that it is something to do only with internet or networked applications. Even though it is true that .NET provides
solid foundation for developing such applications it is possible to create many other types of applications. Following list will give you an idea about various
types of application that we can develop on .NET.
1. ASP.NET Web applications:
These include dynamic and data driven browser
based applications.
2. Windows Form based applications:
These refer to traditional rich client applications.
3. Console applications:
These refer to traditional DOS kind of applications like
batch scripts.
4. Component Libraries:
This refers to components that typically encapsulate
some business logic.
5. Windows Custom Controls:
As with traditional ActiveX controls, you can develop your own windows controls.
6. Web Custom Controls:
The concept of custom controls can be extended to
web applications allowing code reuse and modularization.
7. Web services:
They are “web callable” functionality available via industry standards like HTTP, XML and SOAP.
8. Windows Services:
They refer to applications that run as services in the
background. They can be configured to start automatically when the system boots up.
As you can clearly see, .NET is not just for creating web application but for almost all kinds of applications that you find under Windows.

Feature Of .NET

Features of .NET

Now that we know some basics of .NET, let us see what makes .NET a wonderful

platform for developing modern applications.

• Rich Functionality out of the box

.NET framework provides a rich set of functionality out of the box. It contains hundreds of classes that provide variety of functionality ready to use in your applications. This means that as a developer you need not go into low level details

of many operations such as file IO, network communication and so on.

Easy development of web applications

ASP.NET is a technology available on .NET platform for developing dynamic and data driven web applications. ASP.NET provides an event driven programming model (similar to Visual Basic 6 that simplify development of web

pages (now called as web forms) with complex user interface. ASP.NET server controls provide advanced user interface elements (like calendar and grids) that save lot of coding from programmer’s side.

• OOPs Support

The advantages of Object Oriented programming are well known. .NET provides a fully object oriented environment. The philosophy of .NET is – “Object is mother of all.” Languages like Visual Basic.NET now support many of the OO

features that were lacking traditionally. Even primitive types like integer and characters can be treated as objects – something not available even in OO languages like C++.

• Multi-Language Support

Generally enterprises have varying skill sets.
For example, a company might have people with skills in Visual Basic, C++, and Java etc. It is an experience that
whenever a new language or environment is invented existing skills are outdated.

This naturally increases cost of training and learning curve. .NET provides something attractive in this area. It supports multiple languages. This means that if you have skills in C++, you need not throw them but just mould them to suit
.NET environment. Currently four languages are available right out of the box namely – Visual Basic.NET, C# (pronounced as C-sharp), Jscript.NET and
Managed C++ (a dialect of Visual C++). There are many vendors that are working on developing language compilers for other languages (20+ language compilers are already available). The beauty of multi language support lies in the
fact that even though the syntax of each language is different, the basic capabilities of each language remain at par with one another.

• Multi-Device Support

Modern lift style is increasingly embracing mobile and wireless devices such as PDAs, mobiles and handheld PCs. . . .NET provides promising platform for programming such devices. .NET Compact Framework and Mobile Internet Toolkit are step ahead in this direction.

• Automatic memory management

While developing applications developers had to develop an eye on system resources like memory. Memory leaks were major reason in failure of applications. .NET takes this worry away from developer by handling memory on its own. The garbage collector takes care of freeing unused objects at appropriate intervals.

• Compatibility with COM and COM+

Before the introduction of .NET, COM was the de-facto standard for componentized software development. Companies have invested lot of money and efforts in developing COM components and controls. The good news is – you can still use COM components and ActiveX controls under .NET. This allows you to use your existing investment in .NET applications. .NET still relies on COM+ for features like transaction management and object pooling. In fact it provides enhanced declarative support for configuring COM+ application right from your source code. Your COM+ knowledge still remains as a valuable asset.

• No more DLL Hell

If you have worked with COM components, you probably are aware of “DLL hell”. DLL conflicts are a common fact in COM world. The main reason behind this was the philosophy of COM – “one version of component across machine”.

Also, COM components require registration in the system registry. .NET ends this DLL hell by allowing applications to use their own copy of dependent DLLs.

Also, .NET components do not require any kind of registration in system registry.

• Strong XML support

Now days it is hard to find a programmer who is unaware of XML. XML has gained such a strong industry support that almost all the vendors have released some kind of upgrades or patches to their existing software to make it “XML compatible”. Currently, .NET is the only platform that has built with XML right into the core framework. .NET tries to harness power of XML in every possible way. In addition to providing support for manipulating and transforming XML
documents, .NET provides XML web services that are based on standards like HTTP, XML and SOAP.

• Ease of deployment and configuration

Deploying windows applications especially that used COM components were always been a tedious task. Since .NET does not require any registration as such,
much of the deployment is simplified. This makes XCOPY deployment viable.

Configuration is another area where .NET – especially ASP.NET – shines over traditional languages. The configuration is done via special files having special
XML vocabulary. Since, most of the configuration is done via configuration files,

there is no need to sit in front of actual machine and configure the application manually. This is more important for web applications; simply FTPing new configuration file makes necessary changes.

• Security

Windows platform was always criticized for poor security mechanisms. Microsoft has taken great efforts to make .NET platform safe and secure for enterprise applications. Features such as type safety, code access security and role based
authentication make overall application more robust and secure.