BrainWare-test/Web/Infrastructure/OrderService.cs

85 lines
2.4 KiB
C#
Raw Normal View History

2018-06-05 16:14:15 +00:00
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
namespace Web.Infrastructure
{
using System.Data;
using Models;
public class OrderService
{
public List<Order> GetOrdersForCompany(int CompanyId)
{
var database = new Database();
// Get the orders
var sql1 =
"SELECT c.name, o.description, o.order_id FROM company c INNER JOIN [order] o on c.company_id=o.company_id";
var reader1 = database.ExecuteReader(sql1);
var values = new List<Order>();
while (reader1.Read())
{
var record1 = (IDataRecord) reader1;
values.Add(new Order()
{
CompanyName = record1.GetString(0),
Description = record1.GetString(1),
OrderId = record1.GetInt32(2),
OrderProducts = new List<OrderProduct>()
});
}
reader1.Close();
//Get the order products
var sql2 =
"SELECT op.price, op.order_id, op.product_id, op.quantity, p.name, p.price FROM orderproduct op INNER JOIN product p on op.product_id=p.product_id";
var reader2 = database.ExecuteReader(sql2);
var values2 = new List<OrderProduct>();
while (reader2.Read())
{
var record2 = (IDataRecord)reader2;
values2.Add(new OrderProduct()
{
OrderId = record2.GetInt32(1),
ProductId = record2.GetInt32(2),
Price = record2.GetDecimal(0),
Quantity = record2.GetInt32(3),
Product = new Product()
{
Name = record2.GetString(4),
Price = record2.GetDecimal(5)
}
});
}
reader2.Close();
foreach (var order in values)
{
foreach (var orderproduct in values2)
{
if (orderproduct.OrderId != order.OrderId)
continue;
order.OrderProducts.Add(orderproduct);
order.OrderTotal = order.OrderTotal + (orderproduct.Price * orderproduct.Quantity);
}
}
return values;
}
}
}