Форум программистов, компьютерный форум, киберфорум
Наши страницы
LINQ
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
entry_point
0 / 0 / 0
Регистрация: 24.10.2017
Сообщений: 8
1

Почему не работает LINQ запрос?

14.01.2019, 03:20. Просмотров 838. Ответов 1
Метки c#, linq (Все метки)

Подчеркивает APIName в where, не могу понять почему.
CS1061 'IAPIName" не содержит определения для "APIName" и не удалось найти метод расширения "APIName", принимающий тип "IAPIName" в качестве первого аргумента (возможно, пропущена директива using или ссылка на сборку).

C#
1
2
3
4
5
6
7
8
namespace DataBaseTools.FieldsInfo.Classes
{
    public interface IAPIName
    {
        string APIName { get; set; }
        int SerialNumber { get; set; }
    }
}

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
using System;
using System.Linq;
using System.Collections.Generic;
using Npgsql;
using DataBaseTools.Properties;
using DataBaseTools.FieldsInfo.Classes;
 
 
namespace DataBaseTools.FieldsInfo
{
    internal class ColumnsInfo<IAPIName>
    {
        #region Singleton
        private static ColumnsInfo<IAPIName> fieldsTypesInfo;
 
        public static ColumnsInfo<IAPIName> GetInstance(Func<NpgsqlDataReader, IAPIName> getValue, string sqlString)
        {
            if (fieldsTypesInfo == null)
                fieldsTypesInfo = new ColumnsInfo<IAPIName>(getValue, sqlString);
            return fieldsTypesInfo;
        }
        #endregion
 
        private List<IAPIName> values = new List<IAPIName>();
 
        public IAPIName[] this[string apiName]
        {
            get
            {
                var result =
                    from value in values
                    where value.APIName == apiName
                    orderby value.APIName
                    select value;
 
                return result.ToArray();
            }
        }
 
        private string connectionString =
            "Host=" + Settings.Default.ip_addres_for_database + ";Username=user2;Password=12345;Database=db11";
 
 
        private ColumnsInfo(Func<NpgsqlDataReader, IAPIName> getValue, string sqlString)
        {
            using (NpgsqlConnection connection = new NpgsqlConnection(connectionString))
            {
                connection.Open();
 
                using (NpgsqlCommand command = new NpgsqlCommand(sqlString, connection))
                {
                    using (NpgsqlDataReader reader = command.ExecuteReader())
                    {
                        values.Add(getValue(reader));
                    }
                }
            }
        }
    }
}
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.01.2019, 03:20
Ответы с готовыми решениями:

Не работает linq to xml запрос
Здравствуйте. У меня есть вот такой xml &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt; -&lt;export...

Почему LINQ to Entity содержит не все методы LINQ to Objects?
Почему не все методы linq to entity содержат все методы?Чем например Linq to object

Переписать SQL запрос в LINQ запрос
День добрый всем. Подскажите, пожалуйста, как можно преобразовать запрос: SELECT Price *...

LINQ запрос к DictionaryBase
запрос к Dictionary работает: Dictionary&lt;string, string&gt; cd; cd = new Dictionary&lt;string,...

SQL запрос в LINQ
Я не понимаю как перобразовать такой SQL-запрос для MS SQL SELECT * FROM sysobjects WHERE type =...

1
OwenGlendower
Супер-модератор
Эксперт .NET
10219 / 8823 / 3775
Регистрация: 17.03.2014
Сообщений: 17,738
Записей в блоге: 1
14.01.2019, 04:06 2
Лучший ответ Сообщение было отмечено entry_point как решение

Решение

entry_point, класс ColumnsInfo объявлен как generic с тип-аргументом IAPIName и это имя перевешивает название типа IAPIName. И далее т.к. никаких ограничений на IAPIName не наложено, то с точки зрения компилятора у него доступны только члены класса Object. Исправляется путем отказа от generic или переименованием тип аргумента с добавлением ограничения по интерфейсу
C#
1
class ColumnsInfo<TApi> where TApi : IAPIName
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.01.2019, 04:06

Запрос с Group By на LINQ
Есть DataTable dt = new DataTable(&quot;index&quot;); dt.Columns.Add(&quot;X&quot;,...

Запрос с группировкой Linq
Доброго времени суток, подскажите как написать вот такой вот запрос на Linq: SELECT pr.Name As...

Создать LINQ запрос
Доброго времени суток! Есть форма поиска с тремя полями: Фамилия, имя и отчество. Необходимо...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru