LINQ-запрос и лямбда-выражения - PullRequest
0 голосов
/ 30 апреля 2010

Я пытаюсь написать запрос LINQ, и у меня возникли проблемы. Я не уверен, являются ли лямбда-выражения ответом или нет, но я думаю, что они могут быть.

В моей форме есть два поля со списком: «Состояние» и «Цвет».

Я хочу выбрать виджеты из моей базы данных на основе значений этих двух выпадающих меню.

Мои виджеты могут находиться в одном из следующих состояний: Не запущено, В производстве, В процессе обработки, В запасе, Продано. Виджеты могут иметь любой цвет в таблице «color» в базе данных.

В поле со списком «State» есть выбор «Not Sold», «In Production / Finishing», «Not Started», «In Production», «In Finishing», «In Inventory», «Sold». (Надеюсь, это говорит само за себя.)

В раскрывающемся списке «Цвет» есть «Все цвета» и отдельный элемент для каждого цвета в базе данных.

Как создать запрос LINQ для выбора нужных виджетов из базы данных на основе раскрывающихся списков?

Ответы [ 3 ]

0 голосов
/ 09 мая 2010

Гораздо больше кода, чем хотелось бы, ну да ладно! Я не был уверен, что полностью понял ваше состояние и состояние выбора, но надеюсь, что мой пример все еще полезен.

    [TestMethod]
    public void SelectionTest()
    {
        var userSelections = GetUserSelections("AllColor", (SelectedState[])Enum.GetValues(typeof(SelectedState)));
        var inventory = this.GetInventory();

        foreach (var currentSelection in userSelections)
        {
            var selection = currentSelection;
            var result = from item in inventory
                         where (item.Color == selection.Color || selection.Color == "AllColor") &&
                            this.GetStates(selection.State).Contains(item.State)
                         select item;

            Console.WriteLine("Item selected for selection: Color:{0} SelectedState:{1}", selection.Color, selection.State);

            foreach (var item in result)
            {
                Console.WriteLine("Item Color:{0};Item State:{1}", item.Color, item.State);
            }
            Console.WriteLine("");
        }
    }

    private IEnumerable<State> GetStates(SelectedState state)
    {
        var list = new List<State>();
        foreach (State currentState in Enum.GetValues(typeof(State)))
        {
            if (((int)currentState & (int)state) == (int)currentState)
            {
                list.Add(currentState);
            }
        }

        return list;
    }

    private IEnumerable<Item> GetInventory()
    {
        return new List<Item>()
                {
                    new Item() {State = State.NotStarted, Color = "Blue"},
                    new Item() {State = State.InFinishing, Color = "Red"},
                    new Item() {State = State.Sold, Color = "Yellow"},
                    new Item() {State = State.Sold, Color = "Blue"},
                    new Item() {State = State.InProduction, Color = "Blue"},
                    new Item() {State = State.InInventory, Color = "Blue"},
                };
    }

    private IEnumerable<UserSelection> GetUserSelections(String color, IEnumerable<SelectedState> states)
    {
        var list = new List<UserSelection>();

        foreach (var state in states)
        {
            list.Add(new UserSelection() { Color = color, State = state });
        }
        return list;
    }

    [Flags]
    private enum State
    {
        NotStarted = 1,
        InProduction = 2,
        InFinishing = 4,
        InInventory = 8,
        Sold = 16
    }

    private enum SelectedState
    {
        NotSold = State.InInventory, //Where does it map? I assume INInventory even if it doesnt make much sense
        InProductionOrFinishing = State.InProduction | State.InFinishing,
        NotStarted = State.NotStarted,
        InProduction = State.InProduction,
        InFinishing = State.InFinishing,
        InInventory = State.InInventory,
        Sold = State.Sold,
        SomeBizarroTrippleState = State.InProduction | State.Sold | State.NotStarted
    }

    private class UserSelection
    {
        public String Color { get; set; }
        public SelectedState State { get; set; }
    }

    private class Item
    {
        public String Color { get; set; }
        public State State { get; set; }
    }
0 голосов
/ 09 мая 2010
var query = db.Widgets;

if (stateFilter == "Not sold")
    query = query.Where(w => w.State != WidgetState.Sold);
else if (stateFilter == "In Production/Finishing")
    query = query.Where(w => w.State == WidgetState.InProduction || w.State == WidgetState.Finishing);

if (colorFilter != "All colors")
    query = query.Where(w => w.Color = colorFilter);

(конечно, у вас должен быть лучший способ проверить выбранное значение из выпадающего списка, тестирование на строках действительно плохо ...)

0 голосов
/ 30 апреля 2010
var WidgetStateChoosen = "Sold";
//var WidgetStateChoosen = "All Widgets";
var WidgetColourChoosen = "Orange";
//var WidgetColourChoosen = "All Colours";

var widgetselected = Widgets.Where
    (w => 
        ( (WidgetStateChoosen == "All Widgets") ?  (w.WidgetState != WidgetStateChoosen) : (w.WidgetState == WidgetStateChoosen) )
        &&
        ( (WidgetColourChoosen == "All Colours") ?  (w.WidgetColour != WidgetColourChoosen) : (w.WidgetColour == WidgetColourChoosen) )
    );
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...