Have you been in a situation were you are asked to call a Web Service where you just have a .wsdl generated from Web Service?
Once i was in a situation where i had to call a service with complex data type as input as well as output.
As a .NET developer we know that we can just make Web Reference to the Server URL and we can have all the underlying definition of target web service.
But what happen when it is not possible to have a live URL for the target web service.
Please find a very simple solution for the same.
you can just ask for the .wsdl file from the user/programmer of the target Web Service.
the next step is to create proxy class based on wsdl file.
wsdl command in .net framework provides you this feature where you can create proxy class for your target web service
on the underlying framework run this command
wsdl \out:[path to your new class file] [path to .wsdl file]
that it.
check for the file at path [path to your new class file]
Add that file to you project.
one thing to check and remember do not forget to change the URL property of generated proxy class.
URL should always point to the URL of your target Web Service.
Thank You
Discussion group for OOP Concepts, Software (Design, Architecture, Analysis, etc..), C#.NET, VB.NET, ASP.NET, MSSQL Server, FireBird and much more..
Friday, July 20, 2012
Friday, July 6, 2012
Choosing a SQLDataSource, LINQDataSource or EntityDataSource
When it comes to selecting DataSource for control data binding now there are lots of options.
You can select from
SQLDataSource
LINQDataSource and
Entity DataSource.
Each one has their own advantage and disadvantage. when i was googleing for the same a came across with a nice article, that i am sharing here.
This article looks at the implications for developers in making a choice between using one of the three different types of Data Sources in Visual Studio. We hope this information may help you in coming to a decision over using a particular type of data control. All three of the control types can be used to both directly update data in tables and update data in views (subject to certain restrictions imposed in views).
If you are not fluent in writing SQL then you will find that you need to get up to speed with SQL to make best use of the control.
In order to use LINQ you need to either use an external program called SQLMetal (supplied with Visual Studio or a better choice is to use the Free utility SQL Metal Builder which provides a more friendly interface for running SQLMetal which is a command line program), or a manual process to create a dbml file in your VS web site. The dbml file is a roadmap of all your tables and views in the application and contains a lot of clever technology that enables LINQ to offer certain advantages over the SQLDataSource.
One other point to consider is the lack of support for the automatic updating of the dbml file. However, using manual techniques new tables and views can be quite easily dragged and dropped onto the dbml layout, and existing tables removed and added back to reflect structural changes.
But remember, you can also mix the use of different DataSources in your WebForms, using the most appropriate choice for the task in-hand.
Article source : http://www.upsizing.co.uk/Art37_VSDataSources.aspx
I do not claim for the authority of this article as i am sharing the whole article from the URL Provided above.
Thank You.
You can select from
SQLDataSource
LINQDataSource and
Entity DataSource.
Each one has their own advantage and disadvantage. when i was googleing for the same a came across with a nice article, that i am sharing here.
This article looks at the implications for developers in making a choice between using one of the three different types of Data Sources in Visual Studio. We hope this information may help you in coming to a decision over using a particular type of data control. All three of the control types can be used to both directly update data in tables and update data in views (subject to certain restrictions imposed in views).
SQLDataSource
This is the oldest technology of the three and has the advantage of simplicity of use for people whom are adept at SQL. The control has separate SQL commands for inserting, deleting and updating data.If you are not fluent in writing SQL then you will find that you need to get up to speed with SQL to make best use of the control.
SQLDataSource -Advantages
- The SQL in each command can make full use of SQL Server functions and SQL syntax, for example we use COALESCE functions to resolve locking issues when updating records.
- Everything uses standard SQL syntax.
SQLDatasource – Disadvantages
- The control cannot utilise SQL Server TIMESTAMP data for optimistic concurrency.
- Whilst the control does support concurrency conflicts by checking that old data values have not changed during a write-back this can get quite complicated and messy.
- You can find issues (for which there are well know solutions) when performing write-backs with concurrency control (compare all values) and null values. VS 2008 will automatically generate the SQL commands to avoid for these problems (we use a slightly different technique to that used by Visual Studio).
- Data Binding from controls such as the GridView to field names containing spaces or other special characters become read-only.
LINQDataSource
This data source is a step down the road in taking away a lot of the technical detail behind making the mechanics of updating data work and freeing up the developer to focus on more application related issues.In order to use LINQ you need to either use an external program called SQLMetal (supplied with Visual Studio or a better choice is to use the Free utility SQL Metal Builder which provides a more friendly interface for running SQLMetal which is a command line program), or a manual process to create a dbml file in your VS web site. The dbml file is a roadmap of all your tables and views in the application and contains a lot of clever technology that enables LINQ to offer certain advantages over the SQLDataSource.
LINQDataSource – Advantages
- The control automatically supports SQL Server TIMESTAMP data types for concurrency control. Checking only timestamp’s and primary keys during write-backs.
- Fieldnames with spaces or special characters get aliased automatically, which allows them to be updated.
- A graphical picture in a dbml file gives an easy to use interface to the database tables and views.
- Views can be manually annotated as having a unique field that acts like a primary key allowing them to be updated (by default they are not updateable).
- All the optimistic write-back code is handled for you.
- The visual complexity of the control is significantly reduced over the SQLDataSource, as all the clever concurrency control is no longer required and the control does not require explicit SQL commands for inserting, updating and deleting data.
- Any spaces in entity names are removed; this is simply an aspect how the technology operates.
LINQDataSource – Disadvantages
- The following applies to Binding in controls on a FormView controls, but NOT ListView, GridView or DetailsView. Updating existing records which have null values in numerical or date fields fail to update. Similarly numerical and date fields can not be easily cleared of any value as this causes failures in the Binding. LINQ is not translating empty strings into null values. The only solution we have found is to ensure that all numeric and date data have default values. For existing records default values need to be supplied if they are missing.
- LINQ Where clauses do not support direct date comparisons, so a work-around is required here. The calculation (Year + Month*31 + Day) can be used for date comparisons, for a date range you need ((RequiredDate.Value.Year > OtherDate.Value.Year)||((RequiredDate.Value.Year == OtherDate.Value.Year) && (RequiredDate.Value.Month*31 + RequiredDate.Value.Day) >= (OtherDate.Value.Month*31 + OtherDate.Value.Day))).
- The dbml must be manually updated, or the complete file re-generated.
- Views require the manual addition annotation of the unique keys to support updateability.
- An external program SQLMetal (supplied) is required to automatically generate a dbml file.
- When writing where clause these are written in a C# style, and those adept at SQL but not C# have new skills to learn (this could be considered an advantage for those with C# skills).
- A view with a name like “Orders Qry” will get changed to OrdersQry, whereas a field called “Qrt 1” becomes Qrt_1. So in the case of table/view names the spaces are removed, but for field names they are replaced with an underscore. This inconsistency has been changed in the EntityDataSource where the “_” is used in both cases.
- If you are using SQL Server schemas such as for example a view called Reporting.vw_tblParameters, then SQLMetal gives this object the same name, but interactive drag and drop in Visual Studio drops of the schema prefix in our applications, making it vw_tblParameters. The different behaviour here is a little confusing.
One other point to consider is the lack of support for the automatic updating of the dbml file. However, using manual techniques new tables and views can be quite easily dragged and dropped onto the dbml layout, and existing tables removed and added back to reflect structural changes.
EntityDataSource
The very latest choice of technology is the EntityDataSource, which extends the approach taken with the LINQDataSource by adding further capabilities.EntityDataSource – Advantages
The newest type of Data Source has most of the advantages of LINQ and offers additional features.- The problems with null data values in LINQDataSources do not occur here.
- The graphical schema can be automatically generated within Visual Studio, and automatically updated for underlying changes made to the database structures.
- Combinations of fields for Views are automatically identified as forming a key.
- As with LINQDataSources, TIMESTAMP concurrency is supported, and problem field names dealt with automatically.
- Any spaces in entity names are replaced with an “_” character, unlike LINQ where they were removed.
- Unlike with LINQ the like keyword can be used in a where clause.
EntityDataSource – Disadvantages
- To make Views updateable you need to write stored procedures for the insert, update and delete operations. (In some ways this is not necessarily a disadvantage, but it is inconvenient when compared against LINQ's ability to do this automatically once given the the keys.
- Views which do not have any underlying unique keys are not able to be added to the data model, in such situations for example if used with DropDownLists consider using an SQLDataSource as an alternative. NOTE this normally affects only a few views, and if the EDM can work out the underlying keys from the base tables then this is not a problem. Using a DropDownList based on a view containing for example (SELECT DISTICT Country FROM Customers) would be a problem.
- Field names in tables such as _Country, get assigned a character prefix C, becoming C_Country. LINQ did not do this and allowed field names to start with a _.
- Foreign keys are not exposed in a table, you need to refer to the other side of the relationship to access key values, for example in an Orders table with a SupplierID related to a Suppliers table, you would refer to the field as Suppliers.SupplierID. If you do not like this approach, then by using views, you can directly refer to the foreign keys.
Summary
If you don’t already have a good reason for choosing a type of datasource and you are willing to learn a little C# style syntax then our recommendation would be to use the EntityDataSource. If you are a hardened SQL fan, and want to explicitly use SQL Server specific functions outside of encapsulating them in views then the older SQLDataSource maybe a better choice.But remember, you can also mix the use of different DataSources in your WebForms, using the most appropriate choice for the task in-hand.
Article source : http://www.upsizing.co.uk/Art37_VSDataSources.aspx
I do not claim for the authority of this article as i am sharing the whole article from the URL Provided above.
Thank You.
Thursday, July 5, 2012
MSSQL Server split function
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE FUNCTION [dbo].[fnSplit] (
@sInputList VARCHAR(8000) -- List of delimited items
, @sDelimiter VARCHAR(8000) = ',' -- delimiter that separates items
)
RETURNS @List TABLE (Offset int, item VARCHAR(8000))
BEGIN
DECLARE @sItem VARCHAR(8000)
declare @index int
set @index = 0
WHILE CHARINDEX(@sDelimiter,@sInputList,0) <> 0
BEGIN
SELECT @sItem=RTRIM(LTRIM(SUBSTRING(@sInputList,1,CHARINDEX(@sDelimiter,@sInputList,0)-1)))
, @sInputList=RTRIM(LTRIM(SUBSTRING(@sInputList,CHARINDEX(@sDelimiter,@sInputList,0)+LEN(@sDelimiter),LEN(@sInputList))))
IF LEN(@sItem) > 0
INSERT INTO @List SELECT @index, @sItem
set @index = @index + 1
END
IF LEN(@sInputList) > 0
INSERT INTO @List SELECT @index, @sInputList
set @index = @index + 1 -- Put the last item in
RETURN
END
This Function returns a Table with two fields.
1) Offset a numeric value you can also use that a Sequence no and
2) Item
Thank you.
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE FUNCTION [dbo].[fnSplit] (
@sInputList VARCHAR(8000) -- List of delimited items
, @sDelimiter VARCHAR(8000) = ',' -- delimiter that separates items
)
RETURNS @List TABLE (Offset int, item VARCHAR(8000))
BEGIN
DECLARE @sItem VARCHAR(8000)
declare @index int
set @index = 0
WHILE CHARINDEX(@sDelimiter,@sInputList,0) <> 0
BEGIN
SELECT @sItem=RTRIM(LTRIM(SUBSTRING(@sInputList,1,CHARINDEX(@sDelimiter,@sInputList,0)-1)))
, @sInputList=RTRIM(LTRIM(SUBSTRING(@sInputList,CHARINDEX(@sDelimiter,@sInputList,0)+LEN(@sDelimiter),LEN(@sInputList))))
IF LEN(@sItem) > 0
INSERT INTO @List SELECT @index, @sItem
set @index = @index + 1
END
IF LEN(@sInputList) > 0
INSERT INTO @List SELECT @index, @sInputList
set @index = @index + 1 -- Put the last item in
RETURN
END
This Function returns a Table with two fields.
1) Offset a numeric value you can also use that a Sequence no and
2) Item
Thank you.
Insert Data from Excel to Access Using OLEDBDataAdapter
The view of this article is to show use of dataAdapter to update Database.
string file = Application.StartupPath + @"\excel.xlsx";
DataSet ds = ImportExcelXLS(file, true);
//SqlConnection conn = new SqlConnection("Data Source=server;Initial Catalog=TestDB;User Id=sa;Password=#######;");
System.Data.OleDb.OleDbConnection conn = new System.Data.OleDb.OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + Application.StartupPath + @"\test.accdb" + ";Persist Security Info=False;");
try
{
conn.Open();
DataSet dataSet = new DataSet();
//SqlDataAdapter adapt = new SqlDataAdapter("select * from test where 0 = 1", conn);
OleDbDataAdapter adapt = new OleDbDataAdapter("select * from test where 0 = 1", conn);
//SqlCommandBuilder sqlBld = new SqlCommandBuilder(adapt);
OleDbCommandBuilder sqlBld = new OleDbCommandBuilder(adapt);
adapt.MissingSchemaAction = MissingSchemaAction.AddWithKey;
adapt.Fill(dataSet, "test");
foreach (DataRow row in ds.Tables[0].Rows)
{
DataRow Newrow = dataSet.Tables["test"].NewRow();
Newrow.ItemArray = row.ItemArray;
dataSet.Tables["test"].Rows.Add(Newrow);
}
//sqlBld = new SqlCommandBuilder(adapt);
sqlBld = new OleDbCommandBuilder(adapt);
adapt.InsertCommand = sqlBld.GetInsertCommand();
adapt.Update(dataSet, "test");
endTime = System.DateTime.Now;
TimeSpan result = endTime - startTime;
string result2 = result.ToString();
MessageBox.Show("Done\nIt took " + result2 +" to write data");
}
catch(Exception exec)
{
this.Cursor = Cursors.Default;
MessageBox.Show(exec.Message);
}
finally
{
this.Cursor = Cursors.Default;
if (conn.State == ConnectionState.Open)
conn.Close();
}
for ImportExcelXLS(file, true);
Please read my previous Post
string file = Application.StartupPath + @"\excel.xlsx";
DataSet ds = ImportExcelXLS(file, true);
//SqlConnection conn = new SqlConnection("Data Source=server;Initial Catalog=TestDB;User Id=sa;Password=#######;");
System.Data.OleDb.OleDbConnection conn = new System.Data.OleDb.OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + Application.StartupPath + @"\test.accdb" + ";Persist Security Info=False;");
try
{
conn.Open();
DataSet dataSet = new DataSet();
//SqlDataAdapter adapt = new SqlDataAdapter("select * from test where 0 = 1", conn);
OleDbDataAdapter adapt = new OleDbDataAdapter("select * from test where 0 = 1", conn);
//SqlCommandBuilder sqlBld = new SqlCommandBuilder(adapt);
OleDbCommandBuilder sqlBld = new OleDbCommandBuilder(adapt);
adapt.MissingSchemaAction = MissingSchemaAction.AddWithKey;
adapt.Fill(dataSet, "test");
foreach (DataRow row in ds.Tables[0].Rows)
{
DataRow Newrow = dataSet.Tables["test"].NewRow();
Newrow.ItemArray = row.ItemArray;
dataSet.Tables["test"].Rows.Add(Newrow);
}
//sqlBld = new SqlCommandBuilder(adapt);
sqlBld = new OleDbCommandBuilder(adapt);
adapt.InsertCommand = sqlBld.GetInsertCommand();
adapt.Update(dataSet, "test");
endTime = System.DateTime.Now;
TimeSpan result = endTime - startTime;
string result2 = result.ToString();
MessageBox.Show("Done\nIt took " + result2 +" to write data");
}
catch(Exception exec)
{
this.Cursor = Cursors.Default;
MessageBox.Show(exec.Message);
}
finally
{
this.Cursor = Cursors.Default;
if (conn.State == ConnectionState.Open)
conn.Close();
}
for ImportExcelXLS(file, true);
Please read my previous Post
Insert Data into Access Database from XML using C#
Add Reference to Microsoft Access 14.0 Object
Add Reference based on Version of Access you are Using I am using Access 2010
string file = Application.StartupPath + @"\excel.xlsx";
DataSet ds = ImportExcelXLS(file, true);
ds.WriteXml(Application.StartupPath + @"\test.xml", XmlWriteMode.WriteSchema);
access.Application _accessData;
_accessData = new access.Application();
_accessData.Visible = false;
_accessData.OpenCurrentDatabase(Application.StartupPath + @"\test.accdb");
_accessData.ImportXML(Application.StartupPath + @"\test.xml", access.AcImportXMLOption.acStructureAndData);
_accessData.CloseCurrentDatabase();
_accessData.Quit(Microsoft.Office.Interop.Access.AcQuitOption.acQuitSaveAll);
_accessData = null;
for Method ImportExcelXLS(file, true);
Please check my previous post for loading Excel Data DataSet.
Add Reference based on Version of Access you are Using I am using Access 2010
string file = Application.StartupPath + @"\excel.xlsx";
DataSet ds = ImportExcelXLS(file, true);
ds.WriteXml(Application.StartupPath + @"\test.xml", XmlWriteMode.WriteSchema);
access.Application _accessData;
_accessData = new access.Application();
_accessData.Visible = false;
_accessData.OpenCurrentDatabase(Application.StartupPath + @"\test.accdb");
_accessData.ImportXML(Application.StartupPath + @"\test.xml", access.AcImportXMLOption.acStructureAndData);
_accessData.CloseCurrentDatabase();
_accessData.Quit(Microsoft.Office.Interop.Access.AcQuitOption.acQuitSaveAll);
_accessData = null;
for Method ImportExcelXLS(file, true);
Please check my previous post for loading Excel Data DataSet.
The Simplest Read Excel to Dataset
Understanding Parameters
FileName: Defines path to Excel File
hasHeaders: Defines whether each column in Excel files has header included
public static DataSet ImportExcelXLS(string FileName, bool hasHeaders)
{
string HDR = hasHeaders ? "Yes" : "No";
string strConn;
if (FileName.Substring(FileName.LastIndexOf('.')).ToLower() == ".xlsx")
strConn = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + FileName + ";Extended Properties=\"Excel 12.0;HDR=" + HDR + ";IMEX=0\"";
else
strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + FileName + ";Extended Properties=\"Excel 8.0;HDR=" + HDR + ";IMEX=0\"";
DataSet output = new DataSet();
using (OleDbConnection conn = new OleDbConnection(strConn))
{
conn.Open();
DataTable schemaTable = conn.GetOleDbSchemaTable(
OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });
foreach (DataRow schemaRow in schemaTable.Rows)
{
string sheet = schemaRow["TABLE_NAME"].ToString();
if (!sheet.EndsWith("_"))
{
try
{
OleDbCommand cmd = new OleDbCommand("SELECT * FROM [" + sheet + "]", conn);
cmd.CommandType = CommandType.Text;
DataTable outputTable = new DataTable(sheet);
output.Tables.Add(outputTable);
new OleDbDataAdapter(cmd).Fill(outputTable);
}
catch (Exception ex)
{
throw new Exception(ex.Message + string.Format("Sheet:{0}.File:F{1}", sheet, FileName), ex);
}
}
}
}
return output;
}
FileName: Defines path to Excel File
hasHeaders: Defines whether each column in Excel files has header included
public static DataSet ImportExcelXLS(string FileName, bool hasHeaders)
{
string HDR = hasHeaders ? "Yes" : "No";
string strConn;
if (FileName.Substring(FileName.LastIndexOf('.')).ToLower() == ".xlsx")
strConn = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + FileName + ";Extended Properties=\"Excel 12.0;HDR=" + HDR + ";IMEX=0\"";
else
strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + FileName + ";Extended Properties=\"Excel 8.0;HDR=" + HDR + ";IMEX=0\"";
DataSet output = new DataSet();
using (OleDbConnection conn = new OleDbConnection(strConn))
{
conn.Open();
DataTable schemaTable = conn.GetOleDbSchemaTable(
OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });
foreach (DataRow schemaRow in schemaTable.Rows)
{
string sheet = schemaRow["TABLE_NAME"].ToString();
if (!sheet.EndsWith("_"))
{
try
{
OleDbCommand cmd = new OleDbCommand("SELECT * FROM [" + sheet + "]", conn);
cmd.CommandType = CommandType.Text;
DataTable outputTable = new DataTable(sheet);
output.Tables.Add(outputTable);
new OleDbDataAdapter(cmd).Fill(outputTable);
}
catch (Exception ex)
{
throw new Exception(ex.Message + string.Format("Sheet:{0}.File:F{1}", sheet, FileName), ex);
}
}
}
}
return output;
}
Tuesday, July 3, 2012
Using ASP.NET AJAX Timer Control and ASP.NET AJAX ModalPopup Dialog
Have you ever used ASP.NET AJAX and Timer Control and ModalPopup Ctonrol on a page?
If yes, Then how you Managed to Display Modalpopup when Timer Control Tick event occurs?
Many of you have faced such situation even i have faced the same.
But i used a very simple solution to handle the same.
What is did it is, Stopped the timer control when i view the ModalDialog and then restart the timer when Modal Pup is closed.
You will ask what is the trick in this.
The answer raises another question. How to handle timer control when you have set Modalpop okControlID and CancelControlID.
Because clicking this control does not raise any server event but it is handle at client side.
In order to achive you have handle timer control at client side instead on Code behind
To achieve the same add OkScript, If you just have one button to Close the Modal Popup Control and you have using through OKControlID.
In that Write below code
okscript="okTimerscript();"
function okTimerscript()
{
var timer = $find('<%= tmrControl.ClientID
timer.set_enabled(true);
Timer._startTimer();
}
you would be wondering about the methods. But, forget about this all these methods will be handled by AJAX Control toolkit Timer.js file.
Enjoy and happy coding...
Thank you.
If yes, Then how you Managed to Display Modalpopup when Timer Control Tick event occurs?
Many of you have faced such situation even i have faced the same.
But i used a very simple solution to handle the same.
What is did it is, Stopped the timer control when i view the ModalDialog and then restart the timer when Modal Pup is closed.
You will ask what is the trick in this.
The answer raises another question. How to handle timer control when you have set Modalpop okControlID and CancelControlID.
Because clicking this control does not raise any server event but it is handle at client side.
In order to achive you have handle timer control at client side instead on Code behind
To achieve the same add OkScript, If you just have one button to Close the Modal Popup Control and you have using through OKControlID.
In that Write below code
okscript="okTimerscript();"
function okTimerscript()
{
var timer = $find('<%= tmrControl.ClientID
timer.set_enabled(true);
Timer._startTimer();
}
you would be wondering about the methods. But, forget about this all these methods will be handled by AJAX Control toolkit Timer.js file.
Enjoy and happy coding...
Thank you.
Displaying Documents in a ASP.NET Modal Dialog Box using Google Doc Viewer
For showing Images there are lots JQuery Plugins available which can accomplish these task and are really good.
But how to show real document to the user, in stead of showing them the option to download you can provide facility to your users where they can view documents without leaving your page.
Today i will show a very simple option for doing the same using good doc viewer.
you might be aware of Google Docs feature where you can store your documents and view and edit the same. But have you ever used the same viewer for viewing document that are stored inside your web directory.
Let see how we can achieve the same using ASP.NET AJAX ModalPopup Control Toolkit.
I will not provide you the ASP.NET page code but will only provide code for related Controls
Like Update Panel, Control for Loading Pupup and closing Popup and Code for Loading document for viewing.
I will provide you the CSS that i have used for display ModalPopUp
.modalbackground
{
background-color:Gray;
opacity: 0.5;
filter:Alpha(opacity=50);
}
.modalpopup
{
background-color:White;
padding:6px 6px 6px 6px;
}
Now lets have the Code behind Event for showing the Document.
I have used Iframe for showing the document in ModalPupup but i am loading the document on Request that is the reason you will find any IFrame tag in in Code posted above.
Please find below code for showing document on Show button Client Event
Done.......
Run your page and check whether you are able to load the document in popup or not..
Some points to remember is that you have access rights to the location from where you are loading the page. and do not forget to add attribute "embed=true" otherwise it will not load in IFrame.
Thank you,
Subscribe to:
Posts (Atom)