Webservices : Cannot implicitly convert type 'System.Xml.Linq.XElement' to 'System.Xml.XmlElement'

I have a scenario where i have created a web service, which returns the first name and last name of the username passed through client(webservice consumer).

but im getting an error in 5th line :Cannot implicitly convert type 'System.Xml.Linq.XElement' to 'System.Xml.XmlElement'

Below is the code using to retrieve data

protected void BindUserDetails(string userName)
    {
        UserService.ServiceSoapClient client = new UserService.ServiceSoapClient();
        DataSet dsresult = new DataSet();
       XmlElement exelement = client.GetUserDetails(userName);
        if (exelement != null)
        {
            XmlNodeReader nodereader = new XmlNodeReader(exelement);
            dsresult.ReadXml(nodereader, XmlReadMode.Auto);
            gvUserDetails.DataSource = dsresult;
            gvUserDetails.DataBind();
        }
        else
        {
            gvUserDetails.DataSource = null;
            gvUserDetails.DataBind();
        }
    }

UserService is the Service reference which i have added. gvUserDetails is the gridview

[WebMethod]
    public XmlElement GetUserDetails(string username) {

        SqlConnection cn = new SqlConnection(ConfigurationManager.ConnectionStrings["TestingCS"].ConnectionString);
        cn.Open();
        SqlCommand cmd = new SqlCommand("select * from userInfo where username=@username", cn);
        cmd.Parameters.AddWithValue("@username", username);
        cmd.ExecuteNonQuery();
        SqlDataAdapter da = new SqlDataAdapter(cmd);
        DataSet ds = new DataSet();
        da.Fill(ds);
        cn.Close();
        XmlDataDocument xmldata = new XmlDataDocument(ds);
        XmlElement xmlElement = xmldata.DocumentElement;
        return xmlElement;



    } 

thanks

Jon Skeet
people
quotationmark

Well the error message seems reasonably clear - GetUserDetails is returning XElement (from LINQ to XML) rather than XmlDocument (from the older API).

This shouldn't be a problem though, as basically you just need to select an element and create an XmlReader from it. It looks like your code can just be changed to:

protected void BindUserDetails(string userName)
{
    UserService.ServiceSoapClient client = new UserService.ServiceSoapClient();
    XElement element = client.GetUserDetails(userName);
    if (element != null)
    {
        DataSet dsresult = new DataSet();
        XmlReader reader = element.CreateReader();
        dsresult.ReadXml(reader, XmlReadMode.Auto);
        gvUserDetails.DataSource = dsresult;
    }
    else
    {
        gvUserDetails.DataSource = null;
    }
    gvUserDetails.DataBind();
}

You could potentially refactor that further to extract the "convert XElement to DataSet" functionality:

// You could *consider* making this an extension method
public static DataSet ToDataSetOrNull(XElement source)
{
    if (source == null)
    {
        return null;
    }
    DataSet result = new DataSet();
    result.ReadXml(source.CreateReader(), XmlReadMode.Auto);
    return result;
}

Then your BindUserDetails code is just:

protected void BindUserDetails(string userName)
{
    UserService.ServiceSoapClient client = new UserService.ServiceSoapClient();
    gvUserDetails.DataSource = ToDataSetOrNull(client.GetUserDetails(userName));
    gvUserDetails.DataBind();
}

... and if you have other "BindXyzDetails" methods, they'll be similarly short.

people

See more on this question at Stackoverflow