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

Entity framework, PostgresException: Ошибка столбец не существует

07.12.2022, 17:41. Показов 754. Ответов 0

Студворк — интернет-сервис помощи студентам
Здравствуйте

Есть база данных, в которой заданы таблицы клиентов и карт клиентов. На C# в WPF мне нужно получить список клиентов с определенной скидкой, когда я в коде пытаюсь получить list клиентов, появляется ошибка: Npgsql.PostgresException: "42703: столбец c.id_card_fkeyid_card не существует. id_card_fkey - это свойство в классе Clients (внешний ключ в бд), id_card - свойство в классе Cards (первичный ключ в бд).

Класс клиента
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
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace DataBaseApp.DBClasses.Classes
{
    [Table("clients")]
    public class Clients
    {
        [Key] public int id_client { get; set; }
        public string first_name { get; set; }
        public string last_name { get; set; }
        public string father_name { get; set; }
        public DateTime birthday { get; set; }
        public string phone_number { get; set; }
        public Passports id_passport_fkey { get; set; }
 
        public Cards id_card_fkey { 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
using DataBaseApp.AdminFrames;
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace DataBaseApp.DBClasses.Classes
{
    [Table("cards")]
    public class Cards
    {
        [Key] public int id_card { get; set; }
        public int amount_total { get; set; }
 
        [NotMapped]
        public int discount
        { 
            get 
            {
                return GetDiscount();
 
            }
            private set { }
        }
 
        private int GetDiscount()
        {
            int discount = 0;
 
            if(amount_total > 20000)
            {
                discount = 10;
            }
            else if (amount_total > 10000)
            {
                discount = 5;
            }
            else if(amount_total > 3000)
            {
                discount = 3;
            }
 
            return discount;
        }
 
    }
}

Класс контекста

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
using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using DataBaseApp.Properties;
using System.Windows.Controls;
using System.Windows.Input;
using Microsoft.EntityFrameworkCore;
using DataBaseApp.DBClasses.Classes;
 
namespace DataBaseApp.DBClasses
{
    public class Context : DbContext
    {
        public Context() : base()
        {
 
        }
 
        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            optionsBuilder
                .UseNpgsql("Host=localhost;Port=5432;" +
                "Database = MyDatabase;Username = postgres;" +
                "Password = 1");
 
        }
 
        public DbSet<Clients> clients { get; set; }
        public DbSet<Cards> cards { get; set; }
        public DbSet<IncomingProduct> incoming_product { get; set; }
        public DbSet<KindOfProduct> kind_of_product { get; set; }
        public DbSet<ListIncoming> list_incoming { get; set; }
        public DbSet<Passports> passports { get; set; }
        public DbSet<Products> product { get; set; }
        public DbSet<Sales> sales { get; set; }
        public DbSet<Shop> shop { get; set; }
        public DbSet<Units> units { 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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using DataBaseApp.DBClasses;
using DataBaseApp.DBClasses.Classes;
 
namespace DataBaseApp.AdminFrames
{
    /// <summary>
    /// Логика взаимодействия для Discount.xaml
    /// </summary>
    public partial class Discount : Page
    {
        private string DiscountAmount;
 
        public Discount()
        {
            InitializeComponent();
        }
 
 
        private void btShowDiscount_Click(object sender, RoutedEventArgs e)
        {
            // заданный размер скидки
            DiscountAmount = cbProduct.Text;
            if (DiscountAmount != null && DiscountAmount != "")
            {
                // получаем объекты из бд и выводим
                using (Context db = new Context())
                { 
                    var clientsList = db.clients.ToList();
                
                    foreach (var client in clientsList)
                    {
                        if (client.id_card_fkey.discount.ToString() != DiscountAmount)
                        {
                            clientsList.Remove(client);
                        }                        
                    }
 
                    for(int i = 0; i < clientsList.Count + 1; i++)
                    {
                        grClientsDiscount.RowDefinitions.Add(new RowDefinition());
                    }
                    for (int i = 0; i < 4; i++)
                    {
                        grClientsDiscount.ColumnDefinitions.Add(new ColumnDefinition());
                    }
 
 
                    for (int i = 1; i < clientsList.Count; i++) // клиенты
                    {
                        // ФИО, телефон + посчитать их + вывод таблицы
 
                        int j = 0;
 
                        TextBlock textBlock1 = new TextBlock
                        {
                            Name = "tbLastName" + i,
                            Text = clientsList[i].last_name,
                            Width = 50
                        };
                        grClientsDiscount.Children.Add(textBlock1);
                        Grid.SetRow(textBlock1, i);
                        Grid.SetColumn(textBlock1, j);
 
                        j++;
 
                        TextBlock textBlock2 = new TextBlock
                        {
                            Name = "tbFirstName" + i,
                            Text = clientsList[i].first_name,
                            Width = 50
                        };
                        grClientsDiscount.Children.Add(textBlock2);
                        Grid.SetRow(textBlock2, i);
                        Grid.SetColumn(textBlock2, j);
 
                        j++;
 
                        TextBlock textBlock3 = new TextBlock
                        {
                            Name = "tbFatherName" + i,
                            Text = clientsList[i].father_name,
                            Width = 50
                        };
                        grClientsDiscount.Children.Add(textBlock3);
                        Grid.SetRow(textBlock3, i);
                        Grid.SetColumn(textBlock3, j);
 
                        j++;
 
                        TextBlock textBlock4 = new TextBlock
                        {
                            Name = "tbPhoneNumber" + i,
                            Text = clientsList[i].phone_number,
                            Width = 50
                        };
                        grClientsDiscount.Children.Add(textBlock4);
                        Grid.SetRow(textBlock4, i);
                        Grid.SetColumn(textBlock4, j);
 
 
                    }
                }
            }
        }
    }
}

В выводе ошибки почему то пишется про столбец id_card_fkeyid_card. То есть он слепил его из внешнего ключа и первичного. Если кто-то сможет объяснить в чем ошибка, буду очень благодарна.

Добавлено через 19 минут
Божий промысел привел меня к статье на метаните "Внешние ключи и навигационные свойства" и я поняла в чем была ошибка. Нужно было изменить код в классах следующим образом, так как навигационные свойство нужно именовать определенным способом:
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
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace DataBaseApp.DBClasses.Classes
{
    [Table("clients")]
    public class Clients
    {
        [Key] public int id_client { get; set; }
        public string first_name { get; set; }
        public string last_name { get; set; }
        public string father_name { get; set; }
        public DateTime birthday { get; set; }
        public string phone_number { get; set; }
 
        [ForeignKey("id_passport_fkey")]
        public Passports Passports { get; set; }
 
        [ForeignKey("id_card_fkey")]
        public Cards Cards { get; set; }
 
    }
}
Надеюсь кому-то это сильно поможет.

Но если я что-то не так поняла и у кого-то есть что написать, буду рада помощи)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.12.2022, 17:41
Ответы с готовыми решениями:

Исключение типа "Npgsql.PostgresException" Microsoft.EntityFrameworkCore.Relational.dll 42703: столбец не существует
Подскажите пожалуйста, в чем может быть ошибка. Вызвано исключение: &quot;Npgsql.PostgresException&quot; в...

Как отформатировать столбец таблицы? Entity framework
Не могу отформатировать вывод времени в формате &quot;HH:mm&quot; в datagridview. Изменение DefaultCellStyle нужной колонки не помогло, вылетают...

Entity Framework добавляет ненужный столбец в запрос
Всем привет! Подскажите, кто в курсе, как сделать связку между классами которые представлюят собой точные копии таблиц из БД? Дело в...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.12.2022, 17:41
Помогаю со студенческими работами здесь

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

Entity framework 6 ошибка entityException
Создаю модель на основе бд в visual studio 2013 entity framework 6. Ниче не меняю, просто пытаюсь получить данные из бд, и вот такая ошибка...

Entity Framework. В чем ошибка?
Пытаюсь подключить БД через Entity Framework, вроде бы все создала,но выдает такую ошибку (P.S. Делаю в первый раз) Вот сам код. ...

Ошибка в Entity Framework Code First
Не могу понять почему возникает ошибка. Помогите, пожалуйста. Делал по этому гайду - https://metanit.com/sharp/entityframework/1.2.php ...

Entity Framework. Ошибка добавления элемента
Подскажите пожалуйста. Пытаюсь добавить элемент (Синхронизируя его с БД) using (ProductionEntities db = new...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru