С Новым годом! Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
1 / 1 / 0
Регистрация: 22.10.2013
Сообщений: 68

Как вытащить значение в Entity Framework?

26.11.2015, 16:28. Показов 2318. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пишу универсальную функцию для экспортирования данных из БД в Excel.

Беру значения из БД:
C#
1
2
UnitOfWork uow = new UnitOfWork();
var list = uow.GetRepository<ApprovedName>().All();
Заполняю масиив с названиями столбцов
C#
1
string []  arrColumns = new string []{"Name", "Description", "RegistrationDate"};
Хочу перебрать все значения из таблице с помощью цикла:
C#
1
foreach (var item in list)
Хотела написать по принципу кода ADO.NET:
C#
1
2
3
4
5
6
7
8
9
foreach (var item in list)
{
 int IndexColumn = new int();
 for (int i = 0; i < arrColumns.Length ;i++)
 {
   var tempVal = item[i];
   _ExcelList.SetCellValue(IndexRow,IndexColumn, tempColumn.ColumnNameInTable);
 } 
}

Но к сожалению для item через точку нет каких либо полезных методов (только перечесление полей)

Можно ли как-то в Entity Framework вытаскивать значение из сущности отталкиваять от передаваемого текстового значения?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.11.2015, 16:28
Ответы с готовыми решениями:

В чем разница между Entity Framework и Entity Framework Core?
В чем разница (если она есть) между entity framework и entity framework core?

Не загружаются данные из SQLite c ошибкой "Строка не распознана как действительное значение DateTime" Entity Framework
Добрый день, подскажите пожалуйста: Имеется проект C# приложение windows form с entity framework code first на борту. С начала entity...

Entity framework не добавляет новое значение в базу данных
Всем привет, делаю возможность добавления в друзья у себя на сайте. У меня есть база, в которой хранятся друзья. С колонками UserId,...

3
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18245 / 14167 / 5366
Регистрация: 17.03.2014
Сообщений: 28,848
Записей в блоге: 1
26.11.2015, 16:53
Solomka, сущностям не нужны методы поэтому их там и нет. Вытащить названия свойтв можно с помощью reflection.

Цитата Сообщение от Solomka Посмотреть сообщение
C#
1
int IndexColumn = new int();
int это value-тип. Его не надо конструировать с помощью new. Достаточно присвоить значение. В данном случае 0.
0
1 / 1 / 0
Регистрация: 22.10.2013
Сообщений: 68
27.11.2015, 08:44  [ТС]
Цитата Сообщение от OwenGlendower Посмотреть сообщение
Solomka, сущностям не нужны методы поэтому их там и нет. Вытащить названия свойтв можно с помощью reflection.


int это value-тип. Его не надо конструировать с помощью new. Достаточно присвоить значение. В данном случае 0.
Прошу прощения за опечатку:
(удаляла стороннюю инофрмацию, чтобы не помещать сути вопроса):
C#
1
2
3
4
5
6
7
8
9
10
11
foreach (var item in list)
{
 int IndexColumn = new int();
 for (int i = 0; i < arrColumns.Length ;i++)
 {
//arrColumns[i] - это как раз название столбца из БД 
   var tempColumn = item[arrColumns[i]];
//следующая сторочка просто записывает значения в конкретную ячейку - её можно убрать она написала просто для иллюстрации
   _ExcelList.SetCellValue(IndexRow,IndexColumn, tempColumn.ColumnNameInTable);
 } 
}
int тут не причём
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18245 / 14167 / 5366
Регистрация: 17.03.2014
Сообщений: 28,848
Записей в блоге: 1
27.11.2015, 11:19
Solomka, я тебе уже ответил - используйю рефлексию. Вот пример:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
SomeEntity item = new SomeEntity { Id = 1, Name = "Ivanov", Created = DateTime.Now };
string[] arrColumns = { "Id", "Name", "Created" };
PropertyInfo[] properties = item.GetType().GetProperties();
for (int i=0; i<arrColumns.Length; i++)
{
    var property = properties.FirstOrDefault(p => p.Name == arrColumns[i]);
    if (property != null)
    {
        object value = property.GetValue(item);
        Console.WriteLine(value);
    }
}
 
class SomeEntity
{
    public int Id { get; set; }
    public string Name { get; set; }
    public DateTime Created { get; set; }
}

Не по теме:

Цитата Сообщение от Solomka Посмотреть сообщение
int тут не причём
К решению задачи это не имеет отношения. Я упомянул об этом в общеобразовательных целях.

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.11.2015, 11:19
Помогаю со студенческими работами здесь

Entity Framework. Удаление entity без удаления связей
Вечер добрый. Есть модель Coder First. Каскадное удаление запрещено. Удаление произвожу так: try { ...

Как обновить Entity Framework
Всем привет. У меня возник вопрос. Я использую Entity Framework. И Если например в базе у меня поменялась процедура (к примеру добавился...

Как подключить БД MS Access к Entity Framework?
Подскажите,плиз, как подключить бд ms access к entity framework?

Как работает Entity Framework Core
Добрый день! В веб проекте будет сканирование штрихкодов, как штрихкод сканируется, полученный код это номер заказа. Этот код далее пройдет...

Entity Framework как настроить отношение
Добрый день, есть вопрос, у меня есть 3 таблицы: ProductType (продукт), PackingType(фасовка), Prices (цены). В чем суть, у каждого продукта...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru