Added extension functions for getting a row by a string id, and deleting a row by a string id.
This commit is contained in:
parent
b323dc14eb
commit
926fff38fd
@ -169,6 +169,31 @@ namespace MontoyaTech.MySqlPlus
|
|||||||
command.Parameters.AddWithValue("@id", id);
|
command.Parameters.AddWithValue("@id", id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Setups this MySqlCommand to get a row from the db by a string id.
|
||||||
|
/// </summary>
|
||||||
|
/// <typeparam name="T"></typeparam>
|
||||||
|
/// <param name="command"></param>
|
||||||
|
/// <param name="id"></param>
|
||||||
|
public static void Get<T>(this MySqlCommand command, string id)
|
||||||
|
{
|
||||||
|
//Get the type of T
|
||||||
|
var rowType = typeof(T);
|
||||||
|
|
||||||
|
//Get the row information.
|
||||||
|
var rowAttribute = rowType.GetCustomAttribute<MySqlRow>();
|
||||||
|
|
||||||
|
//Get the id field
|
||||||
|
if (!rowType.GetMySqlPrimaryKey(out FieldInfo primaryField, out MySqlColumn primaryColumn))
|
||||||
|
throw new Exception("Failed to find the primary key for the given row.");
|
||||||
|
|
||||||
|
//Set the command text.
|
||||||
|
command.CommandText = $"SELECT * FROM `{(rowAttribute == null || string.IsNullOrWhiteSpace(rowAttribute.Name) ? rowType.Name : rowAttribute.Name)}` WHERE `{(string.IsNullOrWhiteSpace(primaryColumn.Name) ? primaryField.Name : primaryColumn.Name)}`=@id LIMIT 1";
|
||||||
|
|
||||||
|
//Add the id parameter.
|
||||||
|
command.Parameters.AddWithValue("@id", id);
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Setups this MySqlCommand to get all the rows of a given type from the db.
|
/// Setups this MySqlCommand to get all the rows of a given type from the db.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -255,6 +280,40 @@ namespace MontoyaTech.MySqlPlus
|
|||||||
command.CommandText = builder.ToString();
|
command.CommandText = builder.ToString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Setups this MySqlCommand to delete a row from the db by it's string id.
|
||||||
|
/// </summary>
|
||||||
|
/// <typeparam name="T"></typeparam>
|
||||||
|
/// <param name="command"></param>
|
||||||
|
/// <param name="id"></param>
|
||||||
|
public static void Delete<T>(this MySqlCommand command, string id)
|
||||||
|
{
|
||||||
|
//Get the type of T
|
||||||
|
var rowType = typeof(T);
|
||||||
|
|
||||||
|
//Get the row information.
|
||||||
|
var rowAttribute = rowType.GetCustomAttribute<MySqlRow>();
|
||||||
|
|
||||||
|
//Start building the query.
|
||||||
|
var builder = new StringBuilder();
|
||||||
|
|
||||||
|
//Write the delete from section
|
||||||
|
builder.Append($"DELETE FROM `{(rowAttribute == null || string.IsNullOrWhiteSpace(rowAttribute.Name) ? rowType.Name : rowAttribute.Name)}` ");
|
||||||
|
|
||||||
|
//Get the primary key field and column.
|
||||||
|
if (!rowType.GetMySqlPrimaryKey(out FieldInfo primaryField, out MySqlColumn primaryColumn))
|
||||||
|
throw new Exception("Failed to find primary key for the given row.");
|
||||||
|
|
||||||
|
//Write the where clause
|
||||||
|
builder.Append($"WHERE `{(string.IsNullOrWhiteSpace(primaryColumn.Name) ? primaryField.Name : primaryColumn.Name)}`=@id LIMIT 1");
|
||||||
|
|
||||||
|
//Add the id parameter.
|
||||||
|
command.Parameters.AddWithValue("@id", id);
|
||||||
|
|
||||||
|
//Set the command text.
|
||||||
|
command.CommandText = builder.ToString();
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Setups this MySqlCommand to delete all rows of a given type from the db.
|
/// Setups this MySqlCommand to delete all rows of a given type from the db.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user