Реализация поиска в MVC 4 - PullRequest
1 голос
/ 31 мая 2019

У меня есть текстовое поле, в котором пользователь вводит строку, в которой он должен искать. Если пользователь вводит только строку из одного слова, я могу получить правильные данные из базы данных, но если пользователь вводит строку из нескольких слов, мой код завершается ошибкой.

Я использую EntityFramework для получения данных.

Вот мой код для получения данных с использованием одной строки слова.

public ActionResult SearchResult(string search)
{
   var j = objCon.Mobiles.Where(oh => oh.MobileName.Contains(search) || oh.Description.Contains(search));
   List<Mobiles> prod = new List<Mobiles>();
   foreach (var p in j)
   {
       Mobiles Mob = new Mobiles();
       Mob.Description = p.Description;
       Mob.ImgUrl = p.Url;
       Mob.MobileName = p.MobileName;
       Mob.Price = Convert.ToString(p.Price);
       Mob.SlNo = p.SlNo;
       prod.Add(Mob);
   }

   return View("~/Views/Product/Index.cshtml", prod);
}

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

string str = null;
string[] strArr = null;
int count = 0;
str = //UserInput;
char[] splitchar = { ' ' };
strArr = str.Split(splitchar);

Ответы [ 2 ]

1 голос
/ 31 мая 2019

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

Сначала создайте мобильный класс:

 public class Mobile
        {
            public int Id { get; set; }

            public string Name { get; set; }

            public string Description { get; set; }
        }

Далее Создать метод расширения, чтобы проверить, есть ли значение:

public static bool ContainsAny(this string haystack, params string[] needles)
        {
            foreach (var needle in needles)
            {
                if (haystack.Contains(needle))    
                    return true;
            }

            return false;
        }  

Окончательно создайте основное тело вместе с данными испытаний:

using System;
using System.Collections.Generic;
using System.Linq;

namespace StackOverFlow
{
    static class Program
    {
        static void Main()
        {
            List<Mobile> mobiles = new List<Mobile>
            {
                new Mobile{Id = 1,Name = "samsung galaxy s3",Description = "model"},
                new Mobile{Id = 2,Name = "nokia N67",Description = "nokia n96 time"},
                new Mobile{Id = 3,Name = "iphone 5s",Description = "test"},
                new Mobile{Id = 4,Name = "samsung galaxy packet",Description = "this time"},
                new Mobile{Id = 5,Name = "iphone ipad",Description = "now"},
                new Mobile{Id = 6,Name = "glx c5",Description = "time"},
            };

            string[] search = "galaxy time 5s".Split(' ');

            var result = mobiles.Where(c => c.Name.ContainsAny(search) ||
                                            c.Description.ContainsAny(search)).ToList();

            foreach (var item in result)
            {
                Console.WriteLine(item.Id + "-" + item.Name + "-" + item.Description);
            }

            Console.ReadKey();
        }
1 голос
/ 31 мая 2019
string str = null;
        string[] strArr = null;
        int count = 0;
        str = search;
        char[] splitchar = { ' ' };
        strArr = str.Split(splitchar);
        for (count = 0; count <= strArr.Length - 1; count++)
        {
            string i = strArr[count];
            var j = objCon.Mobiles.Where(oh => oh.MobileName.Contains(i) || oh.Description.Contains(i));
            //MessageBox.Show(strArr[count]); 
            foreach (var p in j)
            {
                Mobiles Mob = new Mobiles();
                Mob.Description = p.Description;
                Mob.ImgUrl = p.Url;
                Mob.MobileName = p.MobileName;
                Mob.Price = Convert.ToString(p.Price);
                Mob.SlNo = p.SlNo;
                prod.Add(Mob);
            }
        }

, поскольку я помогаю вам решить проблему - это окончательный код

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...