using System; using System.Collections.Generic; using System.Data; using System.Linq; using System.Text; namespace TShockDBEditor { public static class DbExt { public static IDbDataParameter AddParameter(this IDbCommand command, string name, object data) { var parm = command.CreateParameter(); parm.ParameterName = name; parm.Value = data; command.Parameters.Add(parm); return parm; } static Dictionary> ReadFuncs = new Dictionary>() { {typeof(bool), (s, i) => s.GetBoolean(i)}, {typeof(byte), (s, i) => s.GetByte(i)}, {typeof(Int16), (s, i) => s.GetInt16(i)}, {typeof(Int32), (s, i) => s.GetInt32(i)}, {typeof(Int64), (s, i) => s.GetInt64(i)}, {typeof(string), (s, i) => s.GetString(i)}, {typeof(decimal), (s, i) => s.GetDecimal(i)}, {typeof(float), (s, i) => s.GetFloat(i)}, {typeof(double), (s, i) => s.GetDouble(i)}, }; public static T Get(this IDataReader reader, string column) { return reader.Get(reader.GetOrdinal(column)); } public static T Get(this IDataReader reader, int column) { if (ReadFuncs.ContainsKey(typeof(T))) return (T)ReadFuncs[typeof(T)](reader, column); throw new NotImplementedException(); } } }