using System; using System.Collections.Generic; using System.Data; using System.Linq; using System.Text; namespace TShockAPI.DB { public static class DbExt { /// /// Executes a query on a database. /// /// Database to query /// Query string with parameters as @0, @1, etc. /// Parameters to be put in the query /// Rows affected by query public static int Query(this IDbConnection db, string query, params object[] args) { using (var com = db.CreateCommand()) { com.CommandText = query; for (int i = 0; i < args.Length; i++) com.AddParameter("@" + i, args[i]); return com.ExecuteNonQuery(); } } /// /// Executes a query on a database. /// /// Database to query /// Query string with parameters as @0, @1, etc. /// Parameters to be put in the query /// Query result as IDataReader public static IDataReader QueryReader(this IDbConnection db, string query, params object[] args) { using (var com = db.CreateCommand()) { com.CommandText = query; for (int i = 0; i < args.Length; i++) com.AddParameter("@" + i, args[i]); return com.ExecuteReader(); } } 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(); } } }