mirror of
https://github.com/stokebob/bnhtrade.git
synced 2026-05-18 19:48:23 +00:00
Feature repricing min max (#10)
amazon settlement import/export improvements
This commit is contained in:
@@ -0,0 +1,198 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Data.SqlClient;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace bnhtrade.Core.Data.Database.Stock
|
||||
{
|
||||
public class UpdateSkuTransaction : Connection
|
||||
{
|
||||
private string err = "Database UpdateSkuTransaction: ";
|
||||
|
||||
public UpdateSkuTransaction(string sqlConnectionString) : base(sqlConnectionString)
|
||||
{
|
||||
}
|
||||
|
||||
public void Update(int skuTransactionId, bool isProcessed)
|
||||
{
|
||||
using (var conn = new SqlConnection(sqlConnectionString))
|
||||
{
|
||||
conn.Open();
|
||||
|
||||
using (SqlCommand cmd = new SqlCommand(@"
|
||||
UPDATE tblStockSkuTransaction
|
||||
SET IsProcessed=@isProcessed
|
||||
WHERE StockSkuTransactionID=@transactionId
|
||||
", conn))
|
||||
{
|
||||
cmd.Parameters.AddWithValue("@isProcessed", isProcessed);
|
||||
cmd.Parameters.AddWithValue("@transactionId", skuTransactionId);
|
||||
|
||||
int effected = cmd.ExecuteNonQuery();
|
||||
|
||||
if (effected < 1)
|
||||
{
|
||||
throw new Exception(err += "Sku Transaction IsProcessed update failed");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Update the StockJournalID field. Will also set the IsProcessed value base on input.
|
||||
/// </summary>
|
||||
/// <param name="skuTransactionId">Sku Transaction Id</param>
|
||||
/// <param name="stockJournalId">Stock Journal Id or null to unset</param>
|
||||
public void Update(int skuTransactionId, int? stockJournalId)
|
||||
{
|
||||
string sql = @"
|
||||
UPDATE tblStockSkuTransaction
|
||||
SET IsProcessed = @isProcessed
|
||||
,StockJournalID = @stockJournalID
|
||||
WHERE StockSkuTransactionID = @transactionId;";
|
||||
|
||||
using (var conn = new SqlConnection(sqlConnectionString))
|
||||
{
|
||||
conn.Open();
|
||||
|
||||
using (SqlCommand cmd = new SqlCommand(sql, conn))
|
||||
{
|
||||
if (stockJournalId == null) { cmd.Parameters.AddWithValue("@stockJournalID", DBNull.Value); }
|
||||
else { cmd.Parameters.AddWithValue("@stockJournalID", (int)stockJournalId); }
|
||||
if (stockJournalId == null) { cmd.Parameters.AddWithValue("@isProcessed", false); }
|
||||
else { cmd.Parameters.AddWithValue("@isProcessed", true); }
|
||||
cmd.Parameters.AddWithValue("@transactionId", skuTransactionId);
|
||||
|
||||
int effected = cmd.ExecuteNonQuery();
|
||||
|
||||
if (effected < 1)
|
||||
{
|
||||
throw new Exception(err += "Sku Transaction StockJournalID update failed");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void Update(int skuTransactionId, int quantity, bool isProcessed)
|
||||
{
|
||||
string sql = @"
|
||||
UPDATE tblStockSkuTransaction
|
||||
SET IsProcessed = @isProcessed
|
||||
,Quantity = @quantity
|
||||
WHERE StockSkuTransactionID = @transactionId;";
|
||||
|
||||
using (var conn = new SqlConnection(sqlConnectionString))
|
||||
{
|
||||
conn.Open();
|
||||
|
||||
using (SqlCommand cmd = new SqlCommand(sql, conn))
|
||||
{
|
||||
cmd.Parameters.AddWithValue("@isProcessed", isProcessed);
|
||||
cmd.Parameters.AddWithValue("@quantity", quantity);
|
||||
cmd.Parameters.AddWithValue("@transactionId", skuTransactionId);
|
||||
|
||||
int effected = cmd.ExecuteNonQuery();
|
||||
|
||||
if (effected < 1)
|
||||
{
|
||||
throw new Exception(err += "Sku Transaction quantity and isprocessed update failed");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Update the StockJournalID field. Will also set the IsProcessed value base on input.
|
||||
/// </summary>
|
||||
/// <param name="skuTransactionId">Sku Transaction Id</param>
|
||||
/// <param name="quantity">Sku Transaction quantity. Set to null to leave database value unchanged.</param>
|
||||
/// <param name="stockJournalId">Stock Journal Id</param>
|
||||
public void Update(int skuTransactionId, int? quantity, int stockJournalId)
|
||||
{
|
||||
string sql = @"
|
||||
UPDATE tblStockSkuTransaction
|
||||
SET IsProcessed = @isProcessed
|
||||
,StockJournalID = @stockJournalID ";
|
||||
|
||||
if (quantity != null)
|
||||
{
|
||||
sql += @"
|
||||
,Quantity = @quantity ";
|
||||
}
|
||||
|
||||
sql += @"
|
||||
WHERE StockSkuTransactionID = @transactionId;";
|
||||
|
||||
using (var conn = new SqlConnection(sqlConnectionString))
|
||||
{
|
||||
conn.Open();
|
||||
|
||||
using (SqlCommand cmd = new SqlCommand(sql, conn))
|
||||
{
|
||||
if (quantity != null) { cmd.Parameters.AddWithValue("@quantity", (int)quantity); }
|
||||
cmd.Parameters.AddWithValue("@isProcessed", true);
|
||||
cmd.Parameters.AddWithValue("@stockJournalID", stockJournalId);
|
||||
cmd.Parameters.AddWithValue("@transactionId", skuTransactionId);
|
||||
|
||||
int effected = cmd.ExecuteNonQuery();
|
||||
|
||||
if (effected < 1)
|
||||
{
|
||||
throw new Exception(err += "Sku Transaction IsProcessed update failed");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void Update(Model.Stock.SkuTransaction skuTransaction)
|
||||
{
|
||||
using (var conn = new SqlConnection())
|
||||
{
|
||||
conn.Open();
|
||||
|
||||
using (SqlCommand cmd = new SqlCommand(@"
|
||||
UPDATE tblStockSkuTransaction
|
||||
SET TransactionDate = @transactionDate
|
||||
,StockSkuTransactionTypeID = @stockSkuTransactionTypeID
|
||||
,ForeignKey = @foreignKey
|
||||
,Reference = @reference
|
||||
,Detail = @Detail
|
||||
,SkuID = (
|
||||
SELECT skuSkuID
|
||||
FROM tblSku
|
||||
WHERE skuSkuNumber = @skuNumber
|
||||
)
|
||||
,Quantity = @quantity
|
||||
,IsProcessed = @isProcessed
|
||||
,StockJournalID = @stockJournalID
|
||||
WHERE StockSkuTransactionID = @transactionId
|
||||
", conn))
|
||||
{
|
||||
cmd.Parameters.AddWithValue("@transactionDate", skuTransaction.TransactionDate.ToUniversalTime());
|
||||
cmd.Parameters.AddWithValue("@stockSkuTransactionTypeID", skuTransaction.SkuTransactionTypeId);
|
||||
if (!skuTransaction.IsSetForeignKey) { cmd.Parameters.AddWithValue("@foreignKey", DBNull.Value); }
|
||||
else { cmd.Parameters.AddWithValue("@foreignKey", skuTransaction.ForeignKey); }
|
||||
if (!skuTransaction.IsSetReference) { cmd.Parameters.AddWithValue("@reference", DBNull.Value); }
|
||||
else { cmd.Parameters.AddWithValue("@reference", skuTransaction.Reference); }
|
||||
if (!skuTransaction.IsSetDetail) { cmd.Parameters.AddWithValue("@detail", DBNull.Value); }
|
||||
else { cmd.Parameters.AddWithValue("@detail", skuTransaction.Detail); }
|
||||
cmd.Parameters.AddWithValue("@skuNumber", skuTransaction.SkuNumber);
|
||||
cmd.Parameters.AddWithValue("@quantity", skuTransaction.Quantity);
|
||||
cmd.Parameters.AddWithValue("@isProcessed", skuTransaction.IsProcessed);
|
||||
if (!skuTransaction.IsSetStockJournalId) { cmd.Parameters.AddWithValue("@stockJournalID", DBNull.Value); }
|
||||
else { cmd.Parameters.AddWithValue("@stockJournalID", skuTransaction.StockJournalId); }
|
||||
cmd.Parameters.AddWithValue("@transactionId", skuTransaction.SkuTransactionId);
|
||||
|
||||
int effected = cmd.ExecuteNonQuery();
|
||||
|
||||
if (effected < 1)
|
||||
{
|
||||
throw new Exception(err += "stockSkuTransaction IsProcessed update failed");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user