LINQ Interview Questions

1. What is mean by LINQ?

LINQ stands for Language Integrated Query. It is a uniform platform for any kind data. It allows us to write a query against Object Collection, Database, XML or other Data source in a standard form without having a separate Query Language.

2. How LINQ works?

Consider the sample customer class with two public members Name and City.

public class Customer
{
public string Name;
public string City;
}


In a console application, customer list with different Name and city are added. Using LINQ retrieve all the customers located in "Coimbatore" city and displays the name of the customer.

//Added a list of customers to the Customers collection list
List Customers = new List(){
new Customer(){Name="Sam",City="Coimbatore"}
,new Customer(){Name="Ram",City="Chennai"}
,new Customer(){Name="Sasi",City="Coimbatore"}};
//Using LINQ to retrive all the customers located in Coimbatore city
var query = from c in Customers
where c.City == "Coimbatore"
select c;
//Displaying all the customer located in Coimbatore city
foreach (Customer c in query)
{
Console.WriteLine(c.Name);

}
Console.ReadLine();
}



The compiler generates the following query for the LINQ

IEnumerable query = Customers.Where(c => c.City == "Coimbatore");

In this compiler generated code, "Where" is a extension method features introduced in C# 3.0 to filter the data based on condition. LINQ make use of these features to query data from object collection. Similar to the Where, we have Select, OrderBy, etc extension methods supported for object collection.

This query will be executed to retrieve data from the collection

3. How will you work with relative model using LINQ?

Using "Join" keyword we can describe relation between two entities as like SQL join statement. E.g In the below query we are joining the Customer collection with Orders collection using CustomerID members. End result we are returning new anonymous type with CustomerID, customer name, orderID as member.

var query = from c in Customers
join o in Orders
on c.CustomerID equals o.Customer.CustomerID
select new { c.CustomerID, c.Name, o.OrderID };


4. In given line of LINQ, when actual query will be executed and why?

In general, a LINQ query is not really executed until there is access the query result, because it describes set of operations that will be performed when necessary. In the below example actual query is executed only in the foreach loop

//Added a list of customers to the Customers collection list
List Customers = new List(){
new Customer(){Name="Sam",City="Coimbatore"}
,new Customer(){Name="Ram",City="Chennai"}
,new Customer(){Name="Sasi",City="Coimbatore"}};
//Using LINQ to retrive all the customers located in Coimbatore city
var query = from c in Customers
where c.City == "Coimbatore"
select c;
//Displaying all the customer located in Coimbatore city
foreach (Customer c in query)
{
Console.WriteLine(c.Name);

}


5. What is mean by declarative programming?

Declarative programming is a programming paradigm that expresses the logic of a computation without describing its control flow. There is main difference between filtering data using SQL query and C# (2.0) language such as table for SQL or an array for C# or VB.net. SQL describes what you want, where as in C# describe how to obtain the expected result. In SQL the selection of the best algorithm to implement the "How" is the responsibility of the query engine. It shows that SQL query engine has more freedom to apply optimization than c#.

6. Is LINQ is Type safe or not?

Data used in the LINQ area always strongly typed, including both the queried collections and the singe entities that are read and returned.

7. What is the use of "Yield" type?

Yeild key word is used to iterate through objects returned by a method. Method with IEnumerable return type can be used with Yeild type.

Example:

public static IEnumerable Power(int num, int exponent)
{
int counter = 1;
int result = 1;
//Loop till the power count reach exponent value
while (counter < exponent)
{
result = result * num;
counter++;
//Returns power of num at each level e.g num, num^2, num^3....
yield return result;
}
}


8. How will you map class with database table in LINQ? Or How will you create Entity class in LINQ?

Class and Database table can be mapped using Table and Column attribute. Table Attribute has Name property to specify the name of the database table. If Name property is not supplied then LINQ-> SQL will assume database table has the same name as the class.Column attribute has few properties which is used to customize the exact mapping between entity and database.

[Table(Name = "Customers")]
public class Customer
{
[Column(IsPrimaryKey = true)]
public string CustomerID;
[Column]
public string Name;
[Column]
public string City;
}


9. Why "from" clause is stated before "select" clause in LINQ which is not available in SQL?

In LINQ, all the query starts with a "from" clause and ends with "Select" clause because Microsoft want to provide IntelliSense capabilities within the remaining part of the query which make writing rest part of the query easier.

10. What is difference between LINQ->SQL and LINQ->Entity?


  • Linq-to-SQL is for direct queries using SQL Server. It's a mapping technology to map SQL Server database tables to .NET objects.
  • Linq-to-Entities is Linq used while using Microsoft's Entity Framework, regardless of db server

11. What are different operators used in LINQ?


  1. Where Operators - Where
  2. Projection Operators - Select, SelectMany
  3. Ordering Operators - OrderBy , OrderByDescending, ThenBy, ThenByDescending, Reverse
  4. Grouping Operators - Group By
  5. Join Operators - Join, GroupJoin
  6. Set Operators - Distinct, Union, Intersect, Except
  7. Aggregate Operators - count, LongCount, Sum,Min,Max, Avagrage, aggregate
  8. Generation Operators - Range, Repeat, Empty
  9. Qualifiers Operators -Any, All, Contains,
  10. Partitioning Operators -Take, TakeWhile, Skip, SkipWhile
  11. Element Operators - First, FirstOrDefault,Single, SingleOrDefault, ElementAt, ElementAtOrDefault, DefaultEmpty
  12. Other Operators - Concat, SequenceEqual

12. What are two main concepts in LINQ?

Two main concepts which is used to understand the LINQ are Deferred query evaluation and Extension method


  • Deferred Query Evaluation - LINQ queries are not evaluated when it is defined but when it is used. It is useful by defining once and used many times when it is required. Result of the query expression will always be based on latest updated content.
  • Extension Method - This allows developer to add functionality in existing class without modifying the existing class or recompiling the existing class or extending the existing class. LINQ make use of this extension method for manipulating data e.g Where, Select...etc

13. What is mean by DLINQ?

DLINQ stands for Data Language Integrated Query, it is also referred to as LINQ to SQL. It is specifically the version of LINQ that focuses on querying data from relational data sources. In Dlinq, DataContext is the main object through which we will be retrieve objects from the database and submit changes back to DB.

14. How SQL query generated from Linq query?

In LINQ, DataContext class is used to communicate between LINQ and SQL. It accept and IConnection class to establish connection with SQL. It uses metadata information to map the Entity with physical structure of database.

[Table(Name = "Customers")]
public class Customer
{
[Column(IsPrimaryKey = true)]
public string CustomerID;
[Column]
public string Name;
[Column]
public string City;
}


15. How will you read data from SQL using Dlinq?

Using DLINQ user can easily read the data from SQL. Visual studio provides inbuilt template to create link between LINQ and SQL.

Example:


  • Create a sample console application and add new item to the project
  • In the shown template select "LINQ to SQL Classes". A new dbml file will be added to your project.
  • Connect to the SQL server using Server Explorer and drag and drop any folder that we need to read the data.
  • This ".dbml" file create a "Employee" Entity mapping to database table. Database column will be mapped to property of the Employee class.


  • Once Table are mapped to Entity, automatically connection string will be added to your application as shown below.

    <connectionStrings>

    <add name="AdventureWorksConnectionString"

    connectionString="Data Source=SARAVANAK-6930\SQLEXPRESS;



    • Initial Catalog=AdventureWorks;Integrated Security=True"


    providerName="System.Data.SqlClient" />

    </connectionStrings>


  • As we discuss DataContext instance is root, through which we can access the corresponding table in database. In the below example I try to read the Employee table with employeeId 1 to 10.
    //Creating connection string for DataContext object
    SqlConnection conn = new SqlConnection();
    string connString = System.Configuration.ConfigurationManager
    .ConnectionStrings["AdventureWorksConnectionString"].ToString();
    conn.ConnectionString = connString;
    //Get the object of the Datacontext
    AdventureWorksDBDataContext adWorksDC = new AdventureWorksDBDataContext(conn);

    //Query from table
    //Read the employee with ID between 1 and 10
    var employees = from emp in adWorksDC.Employees
    where emp.EmployeeID >=1 && emp.EmployeeID<10
    select emp;

    foreach (Employee e in employees )
    {
    Console.WriteLine(String.Format("LoginName: {0}", e.LoginID) );
    }


    Output:


16. How will you Insert record to DB table using LINQ?

A new data record can be inserted to Database table using InsertOnSubmit() method available in DataContext instance. Developer should call the SubmitChanges() method to commit the database transaction else data will not be insert in database table.

Example:

Below sample code shows to insert new Product Category record to database using LINQ.

        //Inserting the Product category into table
ProductCategory cate = new ProductCategory();
cate.ProductCategoryID = 5;
cate.Name = "New Category";
cate.rowguid = System.Guid.NewGuid();
cate.ModifiedDate = DateTime.Now;
adWorksDC.ProductCategories.InsertOnSubmit (cate);
adWorksDC.SubmitChanges();



17. How to update data using linq?

Database update can be done using "SubmitChanges()" method in DataContext instance.

18. How will you call Store procedure using LINQ?

We can call the store procedure define in DB using "Function" and "Parameter" attribute. Consider the below example where user need to call the store procedure "uspGetEmployeeManagers" using LINQ->SQL, for which method "GetEmployeeManagers" will be decorated with Function attribute which requires "Name" property to mention to which SP need to call. If SP requires parameter value, these values can be passed using "Parameter" attribute. SP can return single or multiple result set. For Single result set we will be mapping with ISingleResult return type for multiple result set method it will return IMultipleResults return type of collection. Objects return by the SP will be mapped to new class with columns are mapped to property of the class.

SP mapped to Method

[System.Data.Linq.Mapping.Function(Name="dbo.uspGetEmployeeManagers")]
public ISingleResult GetEmployeeManagers([System.Data.Linq.Mapping.
Parameter(Name="EmployeeID", DbType="Int")] System.Nullable employeeID)
{
IExecuteResult result = this.ExecuteMethodCall(this,
((MethodInfo)(MethodInfo.GetCurrentMethod())), employeeID);
return ((ISingleResult)(result.ReturnValue));
}


Calling SP using method

////Creating connection string for DataContext object
SqlConnection conn = new SqlConnection();
string connString = System.Configuration.ConfigurationManager
.ConnectionStrings["AdventureWorksConnectionString"].ToString();
conn.ConnectionString = connString;
//Get the object of the Datacontext
AdventureWorksDBDataContext adWorksDC = new AdventureWorksDBDataContext(conn);

//Calling SP using method and iterating through values
foreach (uspGetEmployeeManagersResult e in adWorksDC.GetEmployeeManagers(1))
{
Console.WriteLine(String.Format("EmpID: {0} Name: {1}", e.EmployeeID, e.FirstName));
}
Console.ReadLine();


19. How will you call User Define Function using LINQ?

Similar to calling store procedure, functions also called using "Function" and "Parameter" attribute.

Please refer "How will you call Store procedure using LINQ?" for more information

Example:Function mapped to a method

[System.Data.Linq.Mapping.Function(Name="dbo.ufnGetContactInformation", IsComposable=true)]
public IQueryable GetContactInformation
([global::System.Data.Linq.Mapping.Parameter(Name="ContactID", DbType="Int")] System
.Nullable contactID)
{
return this.CreateMethodCallQuery(
this, ((MethodInfo)(MethodInfo.GetCurrentMethod())), contactID);
}


Calling function using LINQ

//Creating connection string for DataContext object
SqlConnection conn = new SqlConnection();
string connString = System.Configuration.ConfigurationManager
.ConnectionStrings["AdventureWorksConnectionString"].ToString();
conn.ConnectionString = connString;
//Get the object of the Datacontext
AdventureWorksDBDataContext adWorksDC = new AdventureWorksDBDataContext(conn);

//Calling Function by passing parameter as '1'
foreach (ufnGetContactInformationResult c in adWorksDC.GetContactInformation (1))
{
Console.WriteLine(String.Format("ContactID: {0} Name: {1}", c.ContactID , c.FirstName));
}


20. How to provide Ready only access to DB?

Suppose if we need to access data only in a read-only way and if we need to improve performance by disabling DataContext class to modify by using ObjectTrackingEnabled property of the Datacontext class

AdventureWorksDBDataContext adWorksDC = new AdventureWorksDBDataContext(conn);
adWorksDC.ObjectTrackingEnabled = false;


21. How will you enable transaction in LINQ->SQL?

A SubmitChanges() in DataContext call automatically starts a database explicit transaction. Using the TransactionScope class contained in the System.Transaction library will be transparently promoted to a distributed transaction.

Example:

    using (TransactionScope ts = new TransactionScope())
{
//Inserting the Product category into table
ProductCategory cate = new ProductCategory();
cate.ProductCategoryID = 5;
cate.Name = "New Category";
cate.rowguid = System.Guid.NewGuid();
cate.ModifiedDate = DateTime.Now;
adWorksDC.ProductCategories.InsertOnSubmit(cate);
adWorksDC.SubmitChanges();
ts.Complete();
}


22. How to create and delete DB from LINQ?

We can create database using DataContext class, if we have a class derived from DataContext that contains entity definition decorated with Table and Column attributes, we can create the corresponding batabase by calling the "CreateDatabase" method.

Example:

MyDatabaseContext myDBContext = new MyDatabaseContext("Data Source=SARAVANAK-6930;
Initial Catalog=MyNewDatabase;Integrated Security=True");
myDBContext.CreateDatabase();



23. What is the LINQ file extension that interacts with Code Behind's objects?

*.dbml

24. What are the error reporting options during concurrency conflicts?

There are two ways to report conflicts while summiting changes to database using linq.

ContinueOnConflict :- Specifies that all the update to the database to be tried and finally return all conflicts at the end of the process.

FailOnFirstConflict :- Specifies that attempts to update database should stop immediately when first concurrency conflicts are detected and return all the conflicts at that moment. In other words LINQ engine does not continue ahead executing the code.

Example:

adWorksDC.SubmitChanges(ConflictMode.FailOnFirstConflict);

25. What are advantages of LINQ over Store procedure?


  • Debugging SP is very difficult, where as LINQ is simple by using visual studio
  • Compile time safety when your schema changes
  • Deployment is easier in linq everything is compiled to dll, where as in DB we need to manage deployment script.

26. What are disadvantage of LINQ over Store procedure?


  • Store procedure can take full advantage of SQL features where as there will be some features missing in LINQ
  • Store process need only serialize SP name and argument data over the wire while LINQ sends the entire query.
  • Redeployment, if we need any modification, we need to recompile assembly in LINQ, where as in SP it is not the case.

27. What is XLINQ?

XLINQ = LINQ->XML, it is XML programming API to query XML data using LINQ. XLINQ provides power of both DOM and XQuery/XPath through LINQ extension methods to manage and query in-memory XML nodes.

28. How will you create xml document object using XLINQ?

XML Document can be created using XDocument, XDeclaration , XElement, XAttribute instance

Example:

XDocument xDocEmployee = new XDocument(
new XDeclaration("1.0", "utf-8", "yes"),
new XElement("Employee",
new XAttribute("ID", "2012"),
new XElement("FirstName", "Ram"),
new XElement("LastName", "Kumar"),
new XElement("Salary", 10000)));


XML document

<?xml version="1.0" encoding="utf-8" standalone="yes" ?>

<Employee ID="2012">

<FirstName>Ram</FirstName>

<LastName>Kumar</LastName>

<Salary>10000</Salary>

</Employee>

29. How will you read xml content using LINQ?

Consider the xml document with list of employee. Below example gives filtering and reading the employee details based on designation.

XML Document

<?xml version="1.0" encoding="utf-8" ?>

<Employees>

  <Employee ID="101">

    <FirstName>Ram</FirstName>

    <LastName>Kumar</LastName>

    <Designation>SE</Designation>

  </Employee>

  <Employee ID="102">

    <FirstName>Sasi</FirstName>

    <LastName>Kumar</LastName>

    <Designation>SSE</Designation>

  </Employee>

  <Employee ID="103">

    <FirstName>Praveen</FirstName>

    <LastName>prakash</LastName>

    <Designation>SSE</Designation>

  </Employee>

</Employees>

LINQ Query

var employees = 
from e in xDocEmployee.Elements("Employee")
where e.Element("Designation").Value == "SSE"
select new { Name = e.Element("FirstName").Value, ID = e.Attribute("ID").Value };


30. How can we do an order by using LINQ query?

Order by in LINQ is pretty simple. We just need to insert order by before the 'Select' query.

var employees = from emp in adWorksDC.Employees 
where emp.EmployeeID >=1 && emp.EmployeeID<10
orderby emp.EmployeeID
select emp;


31. What is the purpose of LINQ Providers in LINQ?

LINQ Providers are a set of classes that takes a LINQ query and dynamically generates a method that executes an equivalent query against a specific data source.

Retrive DynamicEntity from FetchXml query

Hi everyone , some times you need to supply a query form outside the code in a MS CRM solution. Using the following code snippet we can create the query dynamically and pass it to the code to get dynamic entities.

Now suppose i need to execute this query

<fetch mapping='logical'>
    <entity name='contact'>
        <filter type='and'>
            <condition attribute='lastname' operator='eq' value='xyz’/>
        </filter>
    </entity>
</fetch>

to get a list of dynamic entitles

Now either we can break the query and let the code just to have the logical section form this fetchXml or we can use the fetchXml as a whole. Now if i break the query  like

<entity name='contact'>
<filter type='and'>
<condition attribute='lastname' operator='eq' value='xyz’/>
</filter>
</entity>
And inside the code i can

		// here new_criteria contains the logical section from fetch xml(see above)
StringBuilder QueryBuilder = new StringBuilder(new_criteria);
QueryBuilder.Insert(0, "", 1);
QueryBuilder.Insert(QueryBuilder.Length, "
", 1);





Now the next thing i need to do is to convert his query to a CRM QueryExpression, thankfully CRM SDK contains some request & response classes to help






//This is the request/response object to Convert the FetchXML into a query expression.
FetchXmlToQueryExpressionRequest conversionRequest = new FetchXmlToQueryExpressionRequest
{
FetchXml = QueryBuilder.ToString()
};

// and here is the response
FetchXmlToQueryExpressionResponse conversionResponse =
(FetchXmlToQueryExpressionResponse)crmService.Execute(conversionRequest);




Now as we know that the query will results multiple records we will use it in RetriveMultiple


//Retrive Multiple Request
RetrieveMultipleRequest retrieve = new RetrieveMultipleRequest();
retrieve.Query = conversionResponse.Query;
retrieve.ReturnDynamicEntities = true;

//Retrieve Multiple Response
RetrieveMultipleResponse retrieved = (RetrieveMultipleResponse)crmService.Execute(retrieve);

if (retrieved.BusinessEntityCollection.BusinessEntities.Count > 0 )
{
for (int entityCount = 0; entityCount < retrieved.BusinessEntityCollection.BusinessEntities.Count; entityCount++)
{
// retrive the first entity form the collection
DynamicEntity entity = (DynamicEntity)retrieved.BusinessEntityCollection.BusinessEntities[entityCount];


}
}



Converting a JavaScript Date object into the proper XML string


function SwConvertDateTimeToXml(dateTime) {

var offset = (ORG_TIMEZONE_OFFSET < 0) ? -ORG_TIMEZONE_OFFSET : ORG_TIMEZONE_OFFSET;
var timezoneOffsetHours = Math.floor(offset / 60);
var timezoneOffsetMinutes = offset - timezoneOffsetHours * 60;

var s =
dateTime.getYear().toString() + "-" +
SwGetFormattedDatePart(dateTime.getMonth() + 1) + "-" +
SwGetFormattedDatePart(dateTime.getDate()) + "T" +
SwGetFormattedDatePart(dateTime.getHours()) + ":" +
SwGetFormattedDatePart(dateTime.getMinutes()) + ":" +
SwGetFormattedDatePart(dateTime.getSeconds()) +
((ORG_TIMEZONE_OFFSET < 0) ? "-" : "+") +
SwGetFormattedDatePart(timezoneOffsetHours) + ":" +
SwGetFormattedDatePart(timezoneOffsetMinutes);

return s;
}

function SwGetFormattedDatePart(value) {
return (value < 10) ? ("0" + value.toString()) : value.toString();
}

Converting an XML date string to a JavaScript Date object


function SwConvertXmlToDateTime(crmDateTimeString) {
var dateTimeParts = crmDateTimeString.split("T");
var dateString = dateTimeParts[0];
var timeString = dateTimeParts[1];
var dateParts = dateString.split("-");
var timeZoneSeparator = (timeString.indexOf("-") != -1) ? "-" : "+";
var timeZoneParts = timeString.split(timeZoneSeparator);
var timeParts = timeZoneParts[0].split(":");

var date = new Date(SwParseInt(dateParts[0]), SwParseInt(dateParts[1]) - 1, SwParseInt(dateParts[2]), SwParseInt(timeParts[0]), SwParseInt(timeParts[1]), SwParseInt(timeParts[2]));
return date;
}

function SwParseInt(value) {
if ((value.length == 2) && (value.substr(0, 1) == "0")) {
value = value.substr(1, 1);
}

return parseInt(value);
}

CrmService proxy for plug-ins that execute in the child pipeline.

We always come across creating a CrmService Proxy for plug-ins that execute in the child pipeline. In a Child pipeline, you must instantiate the CrmService or MetadataService manually. We just need to check the InvocationSource Property (Child = 1, Parent = 0) of the IPluginExecutionContext. Pass the InvocationSource Property value to the below method.

Below is very simple code which creates a proxy.




public class CRM4_ServiceProx
{


/// The execution context that was passed to the plug-in's Execute method.
/// Set to True to use impersonation.
/// A CrmServce instance.
private CrmService CreateCrmService(IPluginExecutionContext context, Boolean flag)
{
CrmAuthenticationToken authToken = new CrmAuthenticationToken();
authToken.AuthenticationType = 0;
authToken.OrganizationName = context.OrganizationName;

// Include support for impersonation.
if (flag)
authToken.CallerId = context.UserId;
else
authToken.CallerId = context.InitiatingUserId;

CrmService service = new CrmService();
service.CrmAuthenticationTokenValue = authToken;
service.UseDefaultCredentials = true;

// Include support for infinite loop detection.
CorrelationToken corToken = new CorrelationToken();
corToken.CorrelationId = context.CorrelationId;
corToken.CorrelationUpdatedTime = context.CorrelationUpdatedTime;
corToken.Depth = context.Depth;
//Get the server name form registry
RegistryKey regkey = Registry.LocalMachine.OpenSubKey("SOFTWARE\\Microsoft\\MSCRM");

service.Url = String.Concat(regkey.GetValue("ServerUrl").ToString(), "/2007/crmservice.asmx");
service.CorrelationTokenValue = corToken;

return service;
}

}


List of Webservices in Dynamics CRM 2011

Here is the list of services avaialable in CRM 2011. May sametimes you make use of some of it http:// crmserver:5555/AppWebServices/ActivitiesWebService.asmx http:// crmserver:5555/AppWebServices/AdvancedFind.asmx http:// crmserver:5555/AppWebServices/Annotation.asmx http:// crmserver:5555/AppWebServices/AppGridWebService.asmx http:// crmserver:5555/AppWebServices/AssociateRecords.asmx http:// crmserver:5555/AppWebServices/BulkDelete.asmx http:// crmserver:5555/AppWebServices/Connection.asmx http:// crmserver:5555/AppWebServices/Currency.asmx http:// crmserver:5555/AppWebServices/CustomerService.asmx http:// crmserver:5555/AppWebServices/DashboardWebService.asmx http:// crmserver:5555/AppWebServices/DateTimeService.asmx http:// crmserver:5555/AppWebServices/DialogList.asmx http:// crmserver:5555/AppWebServices/DocumentManagementWebService.asmx http:// crmserver:5555/AppWebServices/DuplicateDetection.asmx http:// crmserver:5555/AppWebServices/EmailTemplateService.asmx http:// crmserver:5555/AppWebServices/FormEditorWebService.asmx http:// crmserver:5555/AppWebServices/GanttControlWebService.asmx http:// crmserver:5555/AppWebServices/GoalManagement.asmx http:// crmserver:5555/AppWebServices/ImportJob.asmx http:// crmserver:5555/AppWebServices/ImportWebService.asmx http:// crmserver:5555/AppWebServices/InteractiveWorkflowWebService.asmx http:// crmserver:5555/AppWebServices/LookupMruWebService.asmx http:// crmserver:5555/AppWebServices/LookupService.asmx http:// crmserver:5555/AppWebServices/MailMerge.asmx http:// crmserver:5555/AppWebServices/MarketingAutomation.asmx http:// crmserver:5555/AppWebServices/MergeRecords.asmx http:// crmserver:5555/AppWebServices/MessageBar.asmx http:// crmserver:5555/AppWebServices/MruWebService.asmx http:// crmserver:5555/AppWebServices/OwnerManager.asmx http:// crmserver:5555/AppWebServices/PaneWebService.asmx http:// crmserver:5555/AppWebServices/PresenceService.asmx http:// crmserver:5555/AppWebServices/QueueItem.asmx http:// crmserver:5555/AppWebServices/RecentlyViewedWebService.asmx http:// crmserver:5555/AppWebServices/RegionalOptions.asmx http:// crmserver:5555/AppWebServices/RelatedInformation.asmx http:// crmserver:5555/AppWebServices/RelationshipRolePicklist.asmx http:// crmserver:5555/AppWebServices/reports.asmx http:// crmserver:5555/AppWebServices/ResourceGroupUI.asmx http:// crmserver:5555/AppWebServices/ResourceSpecTree.asmx http:// crmserver:5555/AppWebServices/Ribbon.asmx http:// crmserver:5555/AppWebServices/SalesForceAutomation.asmx http:// crmserver:5555/AppWebServices/SavedQuerySelectorWebService.asmx http:// crmserver:5555/AppWebServices/SchedulePlanning.asmx http:// crmserver:5555/AppWebServices/ScheduleService.asmx http:// crmserver:5555/AppWebServices/ScriptError.asmx http:// crmserver:5555/AppWebServices/Service.asmx http:// crmserver:5555/AppWebServices/Solution.asmx http:// crmserver:5555/AppWebServices/SubjectManager.asmx http:// crmserver:5555/AppWebServices/SystemCustomization.asmx http:// crmserver:5555/AppWebServices/TransactionCurrencyWebService.asmx http:// crmserver:5555/AppWebServices/UserEntityUISettings.asmx http:// crmserver:5555/AppWebServices/UserManager.asmx http:// crmserver:5555/AppWebServices/UserQuery.asmx http:// crmserver:5555/AppWebServices/View.asmx http:// crmserver:5555/AppWebServices/Workflow.asmx http:// crmserver:5555/MSCRMServices/Metadata.asmx http:// crmserver:5555/MSCRMServices/2007/CrmService.asmx http:// crmserver:5555/MSCRMServices/2007/MetadataService.asmx http:// crmserver:5555/MSCRMServices/2007/AD/CrmDiscoveryService.asmx

Passing Data Between Plug-ins [Microsoft Dynamics CRM 4.0]

The message pipeline model provides for a PropertyBag of custom data values in the execution context that is passed through the pipeline and shared among registered plug-ins. This collection of data can be used by different plug-ins to communicate information between plug-ins and enable chain processing where data processed by one plug-in can be processed by the next plug-in in the sequence and so on. This feature is especially useful in pricing engine scenarios where multiple pricing plug-ins pass data between one another to calculate the total price for a sales order or invoice. Another potential use for this feature is to communicate information between a plug-in registered for a pre-event and a plug-in registered for a post-event.

The name of the parameter that is used for passing information between plug-ins is SharedVariables. This is a collection of System.Object. A common type of object that is used to fill the collection is DynamicEntity. At run time, plug-ins can add, read, or modify properties in the SharedVariables property bag. This provides a method of information communication among plug-ins.

Note Only types that are XML serializable should be placed in SharedVariables. All types derived from BusinessEntity are XML serializable.

The following code example shows how to use SharedVariables to pass data from a pre-event registered plug-in to a post-event registered plug-in.



using System;
using Microsoft.Crm.Sdk;
using Microsoft.Crm.SdkTypeProxy;

public class AccountSetStatePreHandler : IPlugin
{
public void Execute(IPluginExecutionContext context)
{
// Create or retrieve some data that will be needed by the post event
// handler. You could run a query, create an entity, or perform a calculation.
//In this sample, the data to be passed to the post plug-in is
// represented by a GUID.
Guid contact = new Guid("{74882D5C-381A-4863-A5B9-B8604615C2D0}");

// Pass the data to the post event handler in an execution context shared
// variable named PrimaryContact.
context.SharedVariables.Properties.Add(
new PropertyBagEntry("PrimaryContact", (Object)contact.ToString()));
// Alternate code: context.SharedVariables["PrimaryContact"] = contact.ToString();
}
}

public class AccountSetStatePostHandler : IPlugin
{
public void Execute(IPluginExecutionContext context)
{
// Obtain the contact from the execution context shared variables.
if (context.SharedVariables.Contains("PrimaryContact"))
{
Guid contact =
new Guid((string)context.SharedVariables["PrimaryContact"]);
// Do something with the contact.
}
}
}




Showing/Hiding tabs based on the selection in a picklist

The next script shows one out of three tabs based on the selection in the new_combo field. It hides all tabs if no selection is made or a different value is selected. OnLoad:


// Jscript
//Sanity check: if new_combo is not present on the form, then don't call FireOnChange
if (crmForm.all.new_combo != null) {
crmForm.all.new_combo.FireOnChange();
}

WCF Interview Questions

1. What is mean by WCF?

Windows Communication Foundation (Code named Indigo) is a programming platform and runtime system for building, configuring and deploying network-distributed services. It is the latest service oriented technology; Interoperability is the fundamental characteristics of WCF. It is unified programming model provided in .Net Framework 3.0. WCF is a combined feature of Web Service, Remoting, MSMQ and COM+. WCF provides a common platform for all .NET communication

2. What is the difference between WCF and Web Service?

Features
Web Service
WCF

Hosting
It can be hosted in IIS
It can be hosted in IIS, windows activation service, Self-hosting, Windows service

Programming
[WebService] attribute has to be added to the class
[ServiceContraact] attribute has to be added to the class

Model
[WebMethod] attribute represents the method exposed to client
[OperationContract] attribute represents the method exposed to client

Operation
One-way, Request- Response are the different operations supported in web service
One-Way, Request-Response, Duplex are different type of operations supported in WCF

XML
System.Xml.serialization name space is used for serialization
System.Runtime.Serialization namespace is used for serialization

Encoding
XML 1.0, MTOM(Message Transmission Optimization Mechanism), DIME, Custom
XML 1.0, MTOM, Binary, Custom

Transports
Can be accessed through HTTP, TCP, Custom
Can be accessed through HTTP, TCP, Named pipes, MSMQ,P2P, Custom

Protocols
Security
Security, Reliable messaging, Transactions

3. What is mean by Endpoint?

WCF Services exposes a collection of Endpoints, each Endpoint is a portal for communicating with the world. Endpoint is used to identify the service; it is more are like an address for your home. Each endpoint is used to identify the specific service. One service can have multiple endpoints. Client application will use this endpoint for communication with service. All the WCF communications are take place through end point. End point consists of three components. Address, Binding and Contract

Address - Basically URL, specifies where this WCF service is hosted .Client will use this url to connect to the service. e.g

http://localhost:8090/MyService/SimpleCalculator.svc

Binding - Binding will describes how client will communicate with service. There are different types of protocols available for the WCF to communicate with the Client.e.g: BasicHttpBinding, WSHttpBinding etc

Contract - Contract specifies the what are the collection of operations that are exposed to the outside world. Usually name of the Interface will be mentioned in the Contract, so the client application will be aware of the operations which are exposed to the client.


4. What is mean by Service contract and its use?

Service contract describes the operation (functionality) that service provides. A Service can have more than one service contract but it should have at least one Service contract.

Service Contract can be define using [ServiceContract] and [OperationContract] attribute. [ServiceContract] attribute is similar to the [WebServcie] attribute in the WebService and [OpeartionContract] is similar to the [WebMethod] in WebService. Attributes mentioned in the service contract are optional.

[ServiceContract(SessionMode=SessionMode.Allowed,
ProtectionLevel=System.Net.Security.ProtectionLevel.EncryptAndSign)]
public interface IMathService
{

[OperationContract]
int Add(int a, int b);

[OperationContract]
int Subtract(int a, int b);

// TODO: Add your service operations here
}


5. What is mean by Operational contract and its use?

Operation contract describers the client-callable operations (functions) exposed as service. Only the functions which are decorated with OperationContract will be exposed to outside world. [OpeartionContract] is similar to the [WebMethod] attribute in WebService implementation.

In the below example only Add() and Subtract() methods are decorated with [OperationContract] and So only these two method will be exposed and used by client application.

[ServiceContract()]
public interface IMathService
{
[OperationContract]
int Add(int num1, int num2);

[OperationContract]
int Subtract(int num1, int num2);

int Multiply(int num1, int num2);

int Divide(int num1, int num2);
}

public class MathService : IMathService
{
public int Add(int num1, int num2)
{
return num1 + num2;
}

public int Subtract(int num1, int num2)
{
return num1 - num2;
}

public int Multiply(int num1, int num2)
{
return num1 * num2;
}

public int Divide(int num1, int num2)
{
return num1 / num2;
}
}


6. What is mean by DataContract and its use?

A data contract is a formal agreement between a service and a client that abstractly describes the data to be exchanged. Data contract can be explicit or implicit. Simple type such as int, string etc has an implicit data contract. User defined object are explicit or Complex type, for which we need to define a Data contract using [DataContract] and [DataMember] attribute.

A data contract can be defined as follows:


  • It describes the external format of data passed to and from service operations
  • It defines the structure and types of data exchanged in service messages
  • It maps a CLR type to an XML Schema
  • It defines how data types are serialized and deserialized

Example: Create user defined data type called Employee. This data type should be identified for serialization and deserialization by mentioning with [DataContract] and [DataMember] attribute.

[ServiceContract]
public interface IEmployeeService
{
[OperationContract]
Employee GetEmployeeDetails(int EmpId);
}

[DataContract]
public class Employee
{
private string m_Name;
private int m_Age;
private int m_Salary;
private string m_Designation;
private string m_Manager;

[DataMember]
public string Name
{
get { return m_Name; }
set { m_Name = value; }
}

[DataMember]
public int Age
{
get { return m_Age; }
set { m_Age = value; }
}

[DataMember]
public int Salary
{
get { return m_Salary; }
set { m_Salary = value; }
}

[DataMember]
public string Designation
{
get { return m_Designation; }
set { m_Designation = value; }
}

[DataMember]
public string Manager
{
get { return m_Manager; }
set { m_Manager = value; }
}

}


7. What is mean by FaultContract?

Fault contract is used to describe the custom exception thrown by service to client. Only if exception class decorated with Fault contract, it can view in client application.

Service that we develop might get error in come case. This error should be reported to the client in proper manner. Basically when we develop managed application or service, we will handle the exception using try- catch block. But these exceptions handlings are technology specific.

In order to support interoperability and client will also be interested not on how and where cause the error, what went wrong?

By default when we throw any exception from service, it will not reach the client side. WCF provides the option to handle and convey the error message to client from service using SOAP Fault contract.

Suppose the service I consumed is not working in the client application. I want to know the real cause of the problem. How I can know the error? For this we are having Fault Contract. Fault Contract provides documented view for error accorded in the service to client. This help as to easy identity the what error has accord.

Example:

You can also create your own Custom type and send the error information to the client using FaultContract. These are the steps to be followed to create the fault contract.


  • Define a type using the data contract and specify the fields you want to return.
  • Decorate the service operation with the FaultContract attribute and specify the type name.
  • Raise the exception from the service by creating an instance and assigning properties of the custom exception.

Step 1: Defining the type using Data Contract

[DataContract()]
public class CustomException
{
[DataMember()]
public string Title;
[DataMember()]
public string ExceptionMessage;
[DataMember()]
public string InnerException;
[DataMember()]
public string StackTrace;
}


Step 2: Decorate the service operation with the FaultContract

    [ServiceContract()]
public interface ISimpleCalculator
{
[OperationContract()]
[FaultContract(typeof(CustomException))]
int Add(int num1, int num2);
}


Step 3: Raise the exception from the service

    public int Add(int num1, int num2)
{
//Do something
CustomException ex = new CustomException();
ex.Title = "Error Funtion:Add()";
ex.ExceptionMessage = "Error occur while doing add function.";
ex.InnerException = "Inner exception message from serice";
ex.StackTrace = "Stack Trace message from service.";
throw new FaultException(ex, "Reason: Testing the Fault contract");

}


8. What is mean by Hosting WCF service?

WCF service cannot exist on its own; it has to be hosted in windows process called as host process. Single host process can host multiple services and same service type can be hosted in multiple host process. There are mainly four different way of hosting the WCF service.


  • IIS hosting
  • Self hosting
  • Windows Activation Service
  • Windows Service

9. What are different types of hosting available in WCF?

WCF service can be hosted in four different ways


  • IIS hosting
  • Self hosting
  • Windows Activation Service
  • Windows Service

Multiple hosting and protocols supported by WCF.Microsoft has introduced the WCF concept in order to make distributed application development and deployment simple.

Hosting Environment
Supported protocol

Windows console and form application
HTTP,net.tcp,net.pipe,net.msmq

Windows service application (formerly known as NT services)
HTTP,net.tcp,net.pipe,net.msmq

Web server IIS6
http, wshttp

Web server IIS7 - Windows Process Activation Service (WAS)
HTTP,net.tcp,net.pipe,net.msmq

10. How will you host the WCF using Windows application?

WCF service can be hosted in windows application using "ServiceHost host" class.

Below example describes the hosting of the CalculatorService in windows application

static void Main(string[] args)
{
//Create a URI to serve as the base address
Uri httpUrl = new Uri("http://localhost:8090/MyService/SimpleCalculator");
//Create ServiceHost
ServiceHost host
= new ServiceHost(typeof(MyCalculatorService.SimpleCalculator), httpUrl);
//Add a service endpoint
host.AddServiceEndpoint(typeof(MyCalculatorService.ISimpleCalculator)
, new WSHttpBinding(), "");
//Enable metadata exchange
ServiceMetadataBehavior smb = new ServiceMetadataBehavior();
smb.HttpGetEnabled = true;
host.Description.Behaviors.Add(smb);
//Start the Service
host.Open();

Console.WriteLine("Service is host at " + DateTime.Now.ToString());
Console.WriteLine("Host is running... Press key to stop");
Console.ReadLine();

}


11. What are different types of binding supported by WCF?


  • BasicHttpBinding
  • WSHttpBinding
  • WSDualHttpBinding
  • WSFederationHttpBinding
  • NetTcpBinding
  • NetNamedPipeBinding
  • NetMsmqBinding
  • NetPeerTcpBinding
  • CustomBinding

12. What is used of different types of binding in WCF?

The real power of wcf resides in binding; each binding are used in different communication scenario. Example BasicHttpBinding are used to communicate outside the firewall or network. Whereas NetTcpbinding are used to communicate between the systems present inside the Local Area Network. The performance for the communication will be increased if we use the NetTcpBinding inside the network. If we use the BasicHttpBinding inside the network, then the performance will degrade. So selection of the right binding of the right communication is very important.

13. What is mean by Message exchange endpoint?

WCF provides rich infrastructure for Exporting, Publishing, retrieving and Importing the metadata (information about the service). WCF uses the Metadata to describe how to interact with the service endpoint. This metadata information of the service is exposed using default endpoint called Message exchange endpoint.

14. What is use of MEX?

Message Exchange Endpoint is used by client application to create the proxy of the service using metadata exposed by MEX.

15. What are different types of bindings supported by MEX?

mexHttpBinding, mexHttpsBinding, mexNamedPipesBinding, mexTcpBinding

16. What is mean by Proxy creation?

The proxy is a class that exposes a single CLR interface representing the service contract. If the service supports several contracts, the client needs a proxy per contract type. The proxy provides the same operations as service's contract, but also has additional methods for managing the proxy life cycle and the connection to the service.

17. What are different types of Proxy creation?

There are different methods available to create the proxy class. These methods are explained by creating the proxy class for the MathService with all some mathematical operation exposed as service.

Method 1:

Using service utility command in visual studio command prompt, we can generate the proxy

Example:

Svcutil "http://localhost:56248/MyMathService/MathService.svc"

Proxy files and its configuration files are generated in default directory of the command prompt MathService.cs and output.config


Method 2: Add Service Reference to the project file

Right click the project file and select "Add Service Reference". Specify the service endpoint address and click "Go" and Math service will be identified and listed. Click OK to create proxy class inside the project application.


Method 3:

By Inheriting ClientBase class

Below example describes the creating the proxy class using Contract information and Channel property of the ClientBase

[ServiceContract]
public interface IMathService
{

[OperationContract]
int Add(int a, int b);

[OperationContract]
int Subtract(int a, int b);
}


public class MyMathServiceProxy : ClientBase
{

public int Add(int a, int b)
{
return this.Channel.Add(a, b);
}

public int Subtract(int a, int b)
{
return this.Channel.Subtract(a, b);
}
}


18. Can we able to call the WCF service without creating Proxy class?

Yes, using "ChannelFactory" we can call the service operation

Example:

private ChannelFactory cf;
private IHelloChannel client;

private void btnSayIt_Click(object sender, EventArgs e)
{
cf = new ChannelFactory("*");
client = cf.CreateChannel();
MessageBox.Show(client.SayHello(txtName.Text));
client.Close();

}



19. What are different types of Behaviors available in WCF?

WCF defines two types of service-side behaviors


  • ServiceBehaviors - It is used to configure service behavior and it will affect all endpoins of the service

    Example: Below service behavior will enable the exposing of service metadata

    <serviceBehaviors>

    <behavior name="ServiceBehavior">

    <serviceMetadata httpGetEnabled="true"/>

    </behavior>

    </serviceBehaviors>


  • EndpointBehaviors - It is used to configure specific endpoint behavior

20. How will you implement function overloading in WCF?

By default WCF will not provide option to overload a function. But method overloading can be achieved using "Name" attribute of the OperationContract.

Below examples describes implementation of function overloading.

[ServiceContract]
public interface IMathService
{

[OperationContract]
int Add(int a, int b);

[OperationContract(Name = "AddDecimal")]
decimal Add(decimal a, decimal b);
}


If we don’t specify the "Name" attribute for the OperationContract. Following error will be displayed while the running the service

Server Error in '/MyMathService' Application.


Cannot have two operations in the same contract with the same name, methods Add and Add in type IMathService violate this rule. You can change the name of one of the operations by changing the method name or by using the Name property of OperationContractAttribute.


21. Will WCF service returns the dataset?

Yes, dataset are serializable object, so WCF service will be able to return the result in dataset format.

22. What is the use of ServiceKnownType attribute?

ServiceKnownType attribute is used to describe the inherited class of the DataContract of the service. Consider a base class and derived class which are decorated with DataContract, when we use base class inside the wcf service, service will be it will able to understand and serialize only the Base class not the derived class. In order to service to know the derived class has to be serialized we need to mention the class name using ServiceKnowType attribute.

Example:

[DataContract]
class Contact
{...}

[DataContract]
class Customer : Contact
{...}

[DataContract]
class Person : Contact
{...}

[ServiceContract]
[ServiceKnownType(typeof(Customer))]
[ServiceKnownType(typeof(Person))]
interface IContactManager
{
[OperationContract]
Contact[] GetContacts( );
}


23. If you use [DataMember] for the private property of the class, will it be exposed to the client application?

No, only public member of the DataContract, which is decorated with DataMember attribute will be exposed to the client.

24. How will you use Enum in WCF?

Enum can be mention in WCF using [EnumMember] attribute

[DataContract]
enum ContactType
{
[EnumMember]
Customer,

[EnumMember]
Vendor,

//Will not be part of data contract
Partner
}


25. What are different levels of service Instance can be managed in WCF?

Instance management refers to the way a service handles a request from a client. Instance management is set of techniques WCF uses to bind client request to service instance, governing which service instance handles which client request.

Basically there are three instance modes in WCF:


  • Per-Call instance mode
  • Per-Session instance mode
  • Singleton Instance Mode

26. What is the mean by Per-Call session?

When WCF service is configured for Per-Call instance mode, Service instance will be created for each client request. This Service instance will be disposed after response is sent back to client.


Example :

[ServiceContract()]
public interface IMyService
{
[OperationContract]
int MyMethod();
}

[ServiceBehavior(InstanceContextMode = InstanceContextMode.PerCall)]
public class MyService : IMyService
{
public int MyMethod()
{
...
}
}


27. What is mean by Per-Session instance?

When WCF service is configured for Per-Session instance mode, logical session between client and service will be maintained. When the client creates new proxy to particular service instance, a dedicated service instance will be provided to the client. It is independent of all other instance.

Following diagram represent the process of handling the request from client using Per-Session instance mode.


Example :

[ServiceContract()]
public interface IMyService
{
[OperationContract]
int MyMethod();
}

[ServiceBehavior(InstanceContextMode = InstanceContextMode.PerSession )]
public class MyService : IMyService
{
public int MyMethod()
{
...
}
}


28. What is mean by Singleton instance?

When WCF service is configured for Singleton instance mode, all clients are independently connected to the same single instance. This singleton instance will be created when service is hosted and, it is disposed when host shuts down.

Following diagram represent the process of handling the request from client using Singleton instance mode.


Example:

[ServiceBehavior(InstanceContextMode = InstanceContextMode.Single )]
public class MyService : IMyService
{
public int MyMethod()
{
...
}
}


29. What is the default Instance Management supported by WCF?

Per-Session instance management

30. What are the different ways to deactivate the service Instance?

When service is configured to use Per-Session instance, WCF provides the option of disposing and recreating the instance within same session.

ReleaseInstanceMode property of the OberationalBehavior attribute used to control the instance in relation to the method call.

Followings are the list Release mode available in the ReleaseInstanceMode


  • RealeaseInstanceMode.None
  • RealeaseInstanceMode.BeforeCall
  • RealeaseInstanceMode.AfterCall
  • RealeaseInstanceMode.BeforeAndAfterCall

Example:

[ServiceContract()]
public interface ISimpleCalculator
{
[OperationContract()]
int Add(int num1, int num2);
}
[OperationBehavior(ReleaseInstanceMode=ReleaseInstanceMode.BeforeCall]
public int Add(int num1, int num2)
{
return num1 + num2;
}


31. What is mean by Durable service?

Durable services are WCF services that persist service state information even after service host is restarted or Client. It means that durable services have the capability to restore their own state when they are recycled. It can use data store like SQL database for maintain instance state. It is new feature in .Net 3.5

32. How will you implement the durable service?

Durable service can be created using following steps


  1. Add "DurableService" attribute to the service class
    [DurableService()]
    public class SimpleCalculator : ISimpleCalculator
    {
    }

  2. Use "wsHttpContextBinding" binding for the endpoint address

      <endpoint address="" binding="wsHttpContextBinding"

    bindingConfiguration="browConfig" contract="ISimpleCalculator">


  3. Add <persistenceProvider> tag in web.config, it is used to configure the persistence provider

    <persistenceProvider

      type="System.ServiceModel.Persistence.SqlPersistenceProviderFactory,

           System.WorkflowServices, Version=3.5.0.0, Culture=neutral,

            PublicKeyToken=31bf3856ad364e35" connectionStringName="DurableServiceStore"

                                persistenceOperationTimeout="00:00:10"

                                lockTimeout="00:01:00"

                                serializeAsText="true"/>


33. What is mean by Throttling in WCF?

WCF throttling provides some properties that you can use to limit how many instances or sessions are created at the application level. Performance of the WCF service can be improved by creating proper instance.

Attribute
Description

maxConcurrentCalls
Limits the total number of calls that can currently be in progress across all service instances. The default is 16.

maxConcurrentInstances
The number of InstanceContext objects that execute at one time across a ServiceHost. The default is Int32.MaxValue.

maxConcurrentSessions
A positive integer that limits the number of sessions a ServiceHost object can accept. The default is 10.

34. Will the Callback operation is supported in WCF?

Yes, Service can also call the functions located at the client side.

35. How will you implement Call back service in WCF?

Call back service can be implemented using "wsDualHttpBinding" binding and CallbackContract property in the ServiceContractattribute.

36. What are mean by Two-phase committed protocol?

Consider the scenario where I am having single client which use single service for communication and interacting with single database. In which service starts and manage the transaction, now it will be easy for the service to manage the transaction.

Consider for example client calling multiple service or service itself calling another service, this type of system are called as Distributed Service-oriented application. Now the questions arise that which service will begin the transaction? Which service will take responsibility of committing the transaction? How would one service know what the rest of the service feels about the transaction? Service could also be deployed in different machine and site. Any network failure or machine crash also increases the complexity for managing the transaction.


In order to overcome these situations, WCF come up with distributed transaction using two way committed protocol and dedicated transaction manager.

Transaction Manager is the third party for the service that will manage the transaction using two phase committed protocol.

37. What are different types of Transaction protocol?

There are three different types of transaction protocol


  1. Lightweight protocol

    • This protocol is used to manage the transaction within same Application Domain
    • Best performance compare to other

  2. OleTx protocol

    • This protocol is used to manage the transaction in an intranet and in a windows environment

  3. WS-Atomic Transaction (WSAT) protocol

    • It can propagate the transaction across the firewalls
    • Primarily used in Internet with multiple transaction managers are involved.

38. What are different types of Transaction manager?


  • Lightweight Transaction Manager (LTM)
  • Kernel Transaction Manager (KTM)
  • Distributed Transaction Coordinator (DTC)

39. What is the use of Lightweight Transaction Manager (LTM)?

LTM can only manage a local transaction; that is, a transaction inside a single app domain. The LTM uses the lightweight transaction protocol to manage the two-phase commit protocol.

40. What is the use of Kernel Transaction Manager (KTM)?

The KTM can be used to manage transactional kernel resource managers (KRM) on Windows Vista, specifically the transactional filesystem (TXF) and the transactional registry (TXR). Transaction can involve at most one service, as long as that service does not propagate the transaction to other services.

41. What is the use of Distributed Transaction Coordinator (DTC)?

The DTC is the transaction manager used when transactions flow across the service boundary. The DTC is a system service available by default on every machine running WCF. Each DTC will communicate with other DTC in different machine to maintain the transaction across the network.

42. What are different levels of Currency mode supported in WCF?

Concurrent access to the service instance is governed by the ConcurrencyMode property of the ServiceBehavior attribute. There are three different types of currency mode


  • Single - Only one caller is allowed to access the service instance
  • Multiple - Concurrent calls are allowed on the service instance
  • Reentrant - concurrent calls on the same instance are never allowed but the reentrant service calls out to another service are allowed.

43. What is the use of dispatcher in WCF?

Dispatcher will receive the message from channel and converts the message to a stack frame and calls the service instance for processing.

44. What is Volatile Queued Communication?

In queued communication, the client communicates to the service using a queue. More precisely, the client sends messages to a queue. The service receives messages from the queue. The service and client therefore, do not have to be running at the same time to communicate using a queue.

When you send a message with no assurances, MSMQ only makes a best effort to deliver the message, unlike with Exactly Once assurances where MSMQ ensures that the message gets delivered or, if it cannot be delivered, lets you know that the message cannot be delivered.

In certain scenarios, you may want to send a volatile message with no assurances over a queue, when timely delivery is more important than losing messages.

Knowing if you are running in CRM 3.0 or CRM 4.0

It's fairly easy to differentiate if your code is running on CRM 4.0 or not. Just pick a method or variable that did not exist in CRM 3.0 and check if it is available:

if (typeof(GenerateAuthenticationHeader) == "undefined") {
alert("Version 3");
}