I am trying to create an aggregate function in C# that will basically find the most occurrence of a value in a column
[Serializable]
[SqlUserDefinedAggregate(Format.Native, Name = "Norm")]
public struct Norm
{
private SerializableDictionary<SqlInt64, int> Pair;
public void Init()
{
//Initialization
Pair = new SerializableDictionary<SqlInt64, int>();
}
public void Accumulate(SqlInt64 Value)
{
//Code removed for easier reading
}
public void Merge(Norm Group)
{
//Code removed for easier reading
}
}
And my SerializableDictionary I have the following code
[XmlRoot("dictionary")]
public class SerializableDictionary<TKey, TValue>
: Dictionary<TKey, TValue>, IXmlSerializable
{
#region IXmlSerializable Members
public System.Xml.Schema.XmlSchema GetSchema()
{
return null;
}
public void ReadXml(System.Xml.XmlReader reader)
{
XmlSerializer keySerializer = new XmlSerializer(typeof(TKey));
XmlSerializer valueSerializer = new XmlSerializer(typeof(TValue));
bool wasEmpty = reader.IsEmptyElement;
reader.Read();
if (wasEmpty)
return;
while (reader.NodeType != System.Xml.XmlNodeType.EndElement)
{
reader.ReadStartElement("item");
reader.ReadStartElement("key");
TKey key = (TKey)keySerializer.Deserialize(reader);
reader.ReadEndElement();
reader.ReadStartElement("value");
TValue value = (TValue)valueSerializer.Deserialize(reader);
reader.ReadEndElement();
this.Add(key, value);
reader.ReadEndElement();
reader.MoveToContent();
}
reader.ReadEndElement();
}
public void WriteXml(System.Xml.XmlWriter writer)
{
XmlSerializer keySerializer = new XmlSerializer(typeof(TKey));
XmlSerializer valueSerializer = new XmlSerializer(typeof(TValue));
foreach (TKey key in this.Keys)
{
writer.WriteStartElement("item");
writer.WriteStartElement("key");
keySerializer.Serialize(writer, key);
writer.WriteEndElement();
writer.WriteStartElement("value");
TValue value = this[key];
valueSerializer.Serialize(writer, value);
writer.WriteEndElement();
writer.WriteEndElement();
}
}
#endregion
}
When I import it into SQL Server the Assembly loads but when I try to execute the following line in SQL Server I get an error
GO
CREATE AGGREGATE Aggregates.Norm (@value BIGINT) RETURNS BIGINT
EXTERNAL NAME WFAggerates.Norm;
The Error I am getting is
Msg 6222, Level 16, State 1, Line 15
Type "WFAggerates.Norm" is marked for native serialization, but field "Pair" of type "WFAggerates.Norm" is not valid for native serialization.
I have already seen these posts but they didn't help me