var range = this.dataStore.Query()
.Range(p => new NotificationConfigurationViewModel(p, from x in p.Events where !(x.Code == null || x.Code.Equals("")) select x.Code), pageNumber);
return this.View(range);
У меня есть приведенный выше код, в котором я хочу вернуть IEnumerable, но получаю
"Подзапрос возвратил более 1 значения. Это не разрешено, когда подзапрос следует за =, !=, = или когда подзапрос используется как выражение при каждом запуске кода. Я понимаю, что запрос хочет вернуть только одно значение, но как мне заставить его возвращать набор значений, как предполагалось? Помогите, пожалуйста!
Позвольте мне немного уточнить... Я хочу, чтобы диапазон включал новый объект. У меня есть запрос, который проходит через базу данных. Он возвращает данные, которые я затем преобразую с помощью следующего конструктора модели представления:
public NotificationConfigurationViewModel(NotificationConfiguration notification , IEnumerable codes)
{
Contract.Requires(notification != null);
this.notification = notification;
this.codes = codes;
}
Каждая конфигурация уведомлений имеет свойства, а затем список связанных с ней событий. Мне нужны только коды из указанного списка.
Просто еще раз поясню. Я хочу, чтобы запрос вернул мне NotificationConfiguration, а также IEnumerable (который я позже преобразую в одну строку с помощью SB). Как только запрос вернет мне эти два элемента, я преобразую его с помощью конструктора в моей модели представления, чтобы я мог правильно отображать все данные с помощью DataTable. Ответ, который я ищу, возможно, очень конкретный, но мне нужно понять, почему я получаю ошибку подзапроса, когда хочу, чтобы он возвращал IEnumerable, и как это исправить. Также обратите внимание... согласно документации .net, код должен вернуть мне IEnumerable, но по какой-то причине он все еще дает сбой. Вот еще раз соответствующие примеры кода:
[HttpPost]
public ActionResult Index(DataTableRequest requestedData)
{
using (this.dataStore.Session.BeginTransaction())
{
return this.dataStore.Query()
.TableRange(requestedData, p => new NotificationConfigurationViewModel(p, from x in p.Events select x.Code));
}
}
.
public NotificationConfigurationViewModel(NotificationConfiguration notification , IEnumerable events)
{
Contract.Requires(notification != null);
this.notification = notification;
this.events = events;
}
.
[Display(Name = "Events")]
public virtual string EventTypeCodes
{
get
{
var codes = new StringBuilder();
foreach (var item in this.events)
{
codes.Append(item + ",");
}
return codes.ToString().TrimEnd(',');
}
}
Подробнее здесь: https://stackoverflow.com/questions/150 ... return-a-s
«Подзапрос возвратил более 1 значения. Это запрещено». Необходимо вернуть набор значений ⇐ C#
Место общения программистов C#
1716441620
Anonymous
var range = this.dataStore.Query()
.Range(p => new NotificationConfigurationViewModel(p, from x in p.Events where !(x.Code == null || x.Code.Equals("")) select x.Code), pageNumber);
return this.View(range);
У меня есть приведенный выше код, в котором я хочу вернуть IEnumerable, но получаю
"Подзапрос возвратил более 1 значения. Это не разрешено, когда подзапрос следует за =, !=, = или когда подзапрос используется как выражение при каждом запуске кода. Я понимаю, что запрос хочет вернуть только одно значение, но как мне заставить его возвращать набор значений, как предполагалось? Помогите, пожалуйста!
Позвольте мне немного уточнить... Я хочу, чтобы диапазон включал новый объект. У меня есть запрос, который проходит через базу данных. Он возвращает данные, которые я затем преобразую с помощью следующего конструктора модели представления:
public NotificationConfigurationViewModel(NotificationConfiguration notification , IEnumerable codes)
{
Contract.Requires(notification != null);
this.notification = notification;
this.codes = codes;
}
Каждая конфигурация уведомлений имеет свойства, а затем список связанных с ней событий. Мне нужны только коды из указанного списка.
Просто еще раз поясню. Я хочу, чтобы запрос вернул мне NotificationConfiguration, а также IEnumerable (который я позже преобразую в одну строку с помощью SB). Как только запрос вернет мне эти два элемента, я преобразую его с помощью конструктора в моей модели представления, чтобы я мог правильно отображать все данные с помощью DataTable. Ответ, который я ищу, возможно, очень конкретный, но мне нужно понять, почему я получаю ошибку подзапроса, когда хочу, чтобы он возвращал IEnumerable, и как это исправить. Также обратите внимание... согласно документации .net, код должен вернуть мне IEnumerable, но по какой-то причине он все еще дает сбой. Вот еще раз соответствующие примеры кода:
[HttpPost]
public ActionResult Index(DataTableRequest requestedData)
{
using (this.dataStore.Session.BeginTransaction())
{
return this.dataStore.Query()
.TableRange(requestedData, p => new NotificationConfigurationViewModel(p, from x in p.Events select x.Code));
}
}
.
public NotificationConfigurationViewModel(NotificationConfiguration notification , IEnumerable events)
{
Contract.Requires(notification != null);
this.notification = notification;
this.events = events;
}
.
[Display(Name = "Events")]
public virtual string EventTypeCodes
{
get
{
var codes = new StringBuilder();
foreach (var item in this.events)
{
codes.Append(item + ",");
}
return codes.ToString().TrimEnd(',');
}
}
Подробнее здесь: [url]https://stackoverflow.com/questions/15069683/subquery-returned-more-than-1-value-this-is-not-permitted-need-to-return-a-s[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия