You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
53 lines
1.7 KiB
53 lines
1.7 KiB
using System;
|
|
using System.Collections.Generic;
|
|
using System.Data.Common;
|
|
using System.Linq;
|
|
|
|
namespace Dapper
|
|
{
|
|
public abstract class SqlCompactDatabase<TDatabase> : Database<TDatabase> where TDatabase : Database<TDatabase>, new()
|
|
{
|
|
public class SqlCompactTable<T> : Table<T>
|
|
{
|
|
public SqlCompactTable(Database<TDatabase> database, string likelyTableName)
|
|
: base(database, likelyTableName)
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// Insert a row into the db
|
|
/// </summary>
|
|
/// <param name="data">Either DynamicParameters or an anonymous type or concrete type</param>
|
|
/// <returns></returns>
|
|
public override int? Insert(dynamic data)
|
|
{
|
|
var o = (object)data;
|
|
List<string> paramNames = GetParamNames(o);
|
|
paramNames.Remove("Id");
|
|
|
|
string cols = string.Join(",", paramNames);
|
|
string colsParams = string.Join(",", paramNames.Select(p => "@" + p));
|
|
|
|
var sql = "insert " + TableName + " (" + cols + ") values (" + colsParams + ")";
|
|
if (database.Execute(sql, o) != 1)
|
|
{
|
|
return null;
|
|
}
|
|
|
|
return (int)database.Query<decimal>("SELECT @@IDENTITY AS LastInsertedId").Single();
|
|
}
|
|
}
|
|
|
|
public static TDatabase Init(DbConnection connection)
|
|
{
|
|
TDatabase db = new TDatabase();
|
|
db.InitDatabase(connection, 0);
|
|
return db;
|
|
}
|
|
|
|
internal override Action<TDatabase> CreateTableConstructorForTable()
|
|
{
|
|
return CreateTableConstructor(typeof(SqlCompactTable<>));
|
|
}
|
|
}
|
|
}
|
|
|