The way I used them was pretty ghetto, I was having troubles getting the objects I needed to serialize to be used in a Session object (I thnk it had something to do with an Order_Details table having two foreign keys to the same table, Ledger, for an IN and OUT field). Anyway, I serialed the object to XML and just stored the whole string into a listBox's value. I know that's begging for poor performance, and overriding the data validation checks is opening the ASP.NET page up for security issues, but the only people who are going to use this are me and my instructor. So, it was a quick work around. I could have stored it in a Session Object as a string, but then I would have had to call some funky work around for the listBox. Anyway, enough about that.
1:
2: /// <summary>
3: /// Serializes a LINQ object to an XML string
4: /// </summary>
5: /// <typeparam name="T">Type of the Object</typeparam>
6: /// <param name="linqObject">The LINQ object to convert</param>
7: /// <returns>string</returns>
8: public static string SerializeLINQtoXML<T>(T linqObject)
9: {
10: // see http://msdn.microsoft.com/en-us/library/bb546184.aspx
11: DataContractSerializer dcs = new DataContractSerializer(linqObject.GetType());
12:
13: StringBuilder sb = new StringBuilder();
14: XmlWriter writer = XmlWriter.Create(sb);
15: dcs.WriteObject(writer, linqObject);
16: writer.Close();
17:
18: return sb.ToString();
19: }
20:
21: /// <summary>
22: /// Deserializes an XML string to a LINQ object
23: /// </summary>
24: /// <typeparam name="T">The type of the LINQ Object</typeparam>
25: /// <param name="input">XML input</param>
26: /// <returns>Type of the LINQ Object</returns>
27: public static T DeserializeLINQfromXML<T>(string input)
28: {
29: DataContractSerializer dcs = new DataContractSerializer(typeof(T));
30:
31: TextReader treader = new StringReader(input);
32: XmlReader reader = XmlReader.Create(treader);
33: T linqObject = (T)dcs.ReadObject(reader, true);
34: reader.Close();
35:
36: return linqObject;
37: }
38: