Introduction
In this article we would see how can we use Linq to Sql ORM in Silverlight 3 Application for interactinig with SQL Server Database.
Creating Silverlight Project
Fire up Visual Studio 2008 and create a new Silverlight 3 Project. Name it as LINQ2SQLSL3.
data:image/s3,"s3://crabby-images/fa4a9/fa4a98c965448739eaed2b9bae0fea92c490db78" alt="LinqToSQLSilverlight1.gif"
Now that you have created the Silverlight 3 Application, we would add a LINQ to SQL file that is *.dbml .
data:image/s3,"s3://crabby-images/1806e/1806ed1df5f11c587444387e748e470a926d5913" alt="LinqToSQLSilverlight2.gif"
For your information, I have created a Database named "EmployeeDB" with a table "EMP_BASIC_INFO" with the following details.
data:image/s3,"s3://crabby-images/68f78/68f780a531ee3203fa9fdf5b3e77abcdef8f4ff5" alt="LinqToSQLSilverlight3.gif"
Now, connect to the SQL Server from Server Explorer as shown in below figure.
data:image/s3,"s3://crabby-images/b9142/b914287a3f74ac1ae9641b6d873eb0b51bdc3f6b" alt="LinqToSQLSilverlight4.gif"
Drag and Drop the above above displayed table to the Object Relational Designer for Linq to SQL.
data:image/s3,"s3://crabby-images/91742/9174232fce290174f57bedb03d679dde521c5df2" alt="LinqToSQLSilverlight5.gif"
Now we would change the above names to be user friendly.
data:image/s3,"s3://crabby-images/2bd0e/2bd0e34b228e1f0f9db0670504220ff9a38b203f" alt="LinqToSQLSilverlight6.gif"
To interact with LINQ to SQL we need to have a service that client can call at any time.
Add Silverlight enabled WCF Service to the Web Project.
data:image/s3,"s3://crabby-images/1c536/1c53631ee4385565de1b5614047ee8ae68566377" alt="LinqToSQLSilverlight7.gif"
In the Service.svc.cs add methods as per your requirement.
I have written two methods such as:
data:image/s3,"s3://crabby-images/364d4/364d4cc545ae0ba5be33b06813ea5c99209175b2" alt="LinqToSQLSilverlight8.gif"
And
data:image/s3,"s3://crabby-images/0dd37/0dd37f0353793eedfa3a90290979f30d7774bac7" alt="LinqToSQLSilverlight9.gif"
After writing the service build the project and get this service's reference in Silverlight 3 Project as shown in below figure.
data:image/s3,"s3://crabby-images/c2174/c21747e35149ea7db747f33fd9ac270ec835a00c" alt="LinqToSQLSilverlight10.gif"
After you add the service it would create the ServiceReferences.ClientConfig file.
Now it's time to design our Silverlight UI in Blend, I have gone for a simple approach, where simple buttons and textbox would help us getting the result which would be displayed in DataGrid.
data:image/s3,"s3://crabby-images/d563f/d563fda9753b76d1ee234b8d16ece57c9287a14a" alt="LinqToSQLSilverlight11.gif"
The following XAML is for your reference:
data:image/s3,"s3://crabby-images/9c77f/9c77f845a42c17a5c988f5e3c3c28882bcd23c84" alt="LinqToSQLSilverlight12.gif"
Now we would write client side code to call the service and display the result.
Following code is for Show All Button Click and displaying the result.
data:image/s3,"s3://crabby-images/58b86/58b860d1bdd2593823102233f5a10528a552c704" alt="LinqToSQLSilverlight13.gif"
Following code is for Show the text typed in txtSearch and based on that the result would be displayed.
data:image/s3,"s3://crabby-images/901bd/901bdc97528433d55fe628d106b13344291e5bcf" alt="LinqToSQLSilverlight14.gif"
I guess that's it. Now we can test our application.
data:image/s3,"s3://crabby-images/8765f/8765f699e9c4802604f70b0c34f07ed476ffa638" alt="LinqToSQLSilverlight15.gif"
When some text is typed and Search Button is clicked all the Employee whose name starts with the given text would be displayed.
data:image/s3,"s3://crabby-images/d1560/d156068638f11c34b8aafe2543c99f48aaf49ec7" alt="LinqToSQLSilverlight16.gif"
Hope this article helps.