Nessuna descrizione

a b165a9d59a 1 2 mesi fa
.vs b165a9d59a 1 2 mesi fa
scrs b165a9d59a 1 2 mesi fa
webapp b165a9d59a 1 2 mesi fa
app1.sln b165a9d59a 1 2 mesi fa
readme.md.txt b165a9d59a 1 2 mesi fa

readme.md.txt

![](./scrs/111.png)

## program c#

```
using MySqlConnector;
using Dapper;

var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();

var dbDataProvider = new DBDataProvider();

app.MapGet("/product", (int? pageNum) =>
{
return dbDataProvider.GetProducts(pageNum ?? 1);
});

app.MapPost("/product", (Product newProduct) =>
{
dbDataProvider.saveProduct(newProduct);
});

app.MapDelete("/product/{id:int}", (int id) =>
{
dbDataProvider.removeProduct(id);
});

app.MapPut("/product", (Product editProduct) =>
{
dbDataProvider.saveProduct(editProduct);
});

app.MapGet("/productCount", () =>
{
return dbDataProvider.GetProductCount();
});

app.MapPut("/minCostForAgent/{minCost:decimal}", (decimal minCost, int[] ids) =>
{
dbDataProvider.setMinCostForAgent(minCost, ids);
});

app.MapGet("/articleCheck/{article}/{ID:int}", (string article, int ID) =>
{
return dbDataProvider.getArticleCheck(article, ID);
});

app.MapGet("/saleCount/{ID:int}", (int ID) =>
{
return dbDataProvider.saleCount(ID);
});

app.MapDelete("/productMaterial/{ID:int}", (int ID) =>
{
dbDataProvider.removeProductMaterial(ID);
});

app.MapDelete("/productCostHistory/{ID:int}", (int ID) =>
{
dbDataProvider.removeProductCostHistory(ID);
});

app.MapGet("/productMaterial/{ID:int}", (int ID) =>
{
return dbDataProvider.getProductMaterials(ID);
});

app.MapGet("/material", () =>
{
return dbDataProvider.getMaterials();
});

app.MapPost("/productMaterial", (ProductMaterial material) =>
{
dbDataProvider.addProductMaterial(material);
});


app.Run();

```

## dbddataprovb

```
public class DBDataProvider
{
public string connectionString = "Server=kolei.ru; User ID=aleuhin; Password=101005; Database=aleuhin";
public List GetProducts(int pageNum)
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
var builder = new SqlBuilder();

// добавление сортировки в запрос
if (orderCondition.Length > 0)
builder.OrderBy(orderCondition);

// добавление фильтрации в запрос
if (filters.Count > 0)
{
foreach (var item in filters)
builder.Where(item.Key, item.Value);
}

// составление шаблона запроса
var template = builder.AddTemplate(
"SELECT * FROM aleuhin.12 /**where**/ /**orderby**/ LIMIT @pageLen OFFSET @offset",
new
{
pageLen = 20,
offset = (pageNum - 1) * 20
}
);

// выполнение запроса
return db.Query
(
template.RawSql,
template.Parameters).ToList();
}
}

private string orderCondition = "";
public void setOrder(string condition)
{
orderCondition = condition;
}

private Dictionary filters = new Dictionary();
public void addFilter(string name, object value)
{
filters.Add(name, value);
}
public void clearFilter()
{
filters.Clear();
}

public void saveProduct(Product product)
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
if (product.ID == 0)
{
db.Execute("INSERT INTO Product" +
"(`Title`, `ProductTypeID`,`ArticleNumber`,`Description`,`Image`," +
"`ProductionPersonCount`,`ProductionWorkshopNumber`,`MinCostForAgent`) " +
"VALUES (@Title,@ProductTypeID,@ArticleNumber,@Description,@Image," +
"@ProductionPersonCount,@ProductionWorkshopNumber,@MinCostForAgent);", product);
}
else
{
db.Execute("UPDATE Product SET Title=@Title, ProductTypeID=@ProductTypeID, " +
"ArticleNumber=@ArticleNumber, Description=@Description, " +
"Image=@Image, ProductionPersonCount=@ProductionPersonCount, " +
"ProductionWorkshopNumber=@ProductionWorkshopNumber, " +
"MinCostForAgent=@MinCostForAgent " +
"WHERE ID=@ID", product);
}
}
}

public void removeProduct(int ID)
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
db.Execute("DELETE FROM Product WHERE ID = @ID", new { ID = ID });
}
}

public int GetProductCount()
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
var builder = new SqlBuilder();
if (filters.Count > 0)
{
foreach (var item in filters)
builder.Where(item.Key, item.Value);
}

var template = builder.AddTemplate(
"SELECT count(*) FROM 12 /**where**/");

return db.QuerySingle(
template.RawSql,
template.Parameters);
}
}

public void setMinCostForAgent(decimal minCostForAgent, int[] ids)
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
db.Execute("UPDATE Product SET MinCostForAgent=@newCost WHERE ID in @idList", new
{
newCost = minCostForAgent,
idList = ids
});
}
}

public int getArticleCheck(string article, int ID)
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
return db.QuerySingle("SELECT count(*) FROM Product " +
"WHERE ArticleNumber=@article AND ID != @ID;", new
{
article = article,
ID = ID
});
}
}


public int saleCount(int ID)
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
if (ID != 0)
{
return db.QuerySingle("SELECT count(*) FROM ProductSale WHERE ProductID=@ID", new { ID = ID });
}
return 0;
}
}

public void removeProductMaterial(int ID)
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
db.Execute("DELETE FROM ProductMaterial WHERE ProductID=@ID", new { ID = ID });
}
}

public void removeProductCostHistory(int ID)
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
db.Execute("DELETE FROM ProductCostHistory WHERE ProductID = @ID", new { ID = ID });
}
}

public List getProductMaterials(int ID)
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
return db.Query("SELECT pm.*,m.Title " +
"FROM ProductMaterial as pm,Material as m " +
"WHERE pm.ProductID = @ID AND m.ID = pm.MaterialID", new { ID = ID }).ToList();
}
}

public void deleteProductMaterial(ProductMaterial material)
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
db.Execute("DELETE FROM ProductMaterial WHERE ProductID = @ProductId AND MaterialID = @MaterialId", material);
}
}

public List getMaterials()
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
return db.Query("SELECT ID,Title FROM aleuhin.Material").ToList();
}
}

public void addProductMaterial(ProductMaterial material)
{
using (MySqlConnection db = new MySqlConnection(connectionString))
{
db.Execute("INSERT INTO ProductMaterial (`ProductID`,`MaterialID`,`Count`) VALUES (@ProductId,@MaterialId,@Count)", material);
}
}
}

```

## classes

```
public class Product
{
public int ID { get; set; }
public string Title { get; set; }
public int ProductTypeID { get; set; }
public string ProductTypeTitle { get; set; }
public string ArticleNumber { get; set; }
public string Description { get; set; }
public string Image { get; set; }
public int ProductionPersonCount { get; set; }
public int ProductionWorkshopNumber { get; set; }
public decimal MinCostForAgent { get; set; }
public int MaterialCost { get; set; }
public string MaterialString { get; set; }
public int? LastMonthSaleQuantity { get; set; }
}

public class ProductMaterial
{
public int ProductId { get; set; }
public int MaterialId { get; set; }
public double Count { get; set; }
}

public class Material
{
public int ID { get; set; }
public string Title { get; set; }
}

```