Проблема, с которой я столкнулся, заключается в следующем: мне нужно получить несколько свойств навигации, чтобы данные отображались на моем интерфейсе. Для их получения я использую .Include().
По умолчанию Include выполняет внутреннее соединение, я это понимаю. Я также читал, что если свойства навигации имеют значение NULL и тип столбца в базе данных может быть нулевым, будет выполнено LEFT JOIN. Мой запрос по-прежнему использует INNER JOIN, хотя оба моих столбца, FK, имеют значение NULL.
Это мой запрос
var listOfProductsOnSets = await productWithSetsRepository
.FindQueryable(asoc => asoc.IdSet == idSet)
.Include(c => c.AsCuloare)
.ThenInclude(cc => cc!.CodCuloare)
.Include(d => d.AsDimensiune)
.AsSplitQuery()
.ToListAsync();
Это мой класс:
public class AsociereSeturi
{
// Attributes
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int IdAsociereSet { get; init; }
// Foreign Keys
public int IdProdus { get; init; }
public Produse Produs { get; init; } = null!;
public int IdSet { get; init; }
public Seturi Set { get; init; } = null!;
public int? IdCuloare { get; init; }
public Culori? AsCuloare { get; init; }
public int? IdDimensiune { get; init; }
public Dimensiuni? AsDimensiune { get; init; }
public ICollection CombinatieSetPeComanda { get; }
}
А это мои журналы:
SELECT a.id_asociere_set, a.id_culoare, a.id_dimensiune, a.id_produs, a.id_set,
c.id_culoare, c.id_cod_culoare, c.nume_culoare,
d.id_dimensiune, d.latime, d.lungime, d.PerdeaEstePereche, d.recomandare_pat
FROM asociere_seturi AS a
INNER JOIN culori AS c ON a.id_culoare = c.id_culoare
INNER JOIN dimensiuni AS d ON a.id_dimensiune = d.id_dimensiune
WHERE a.id_set = @__idSet_0;
РЕДАКТИРОВАНИЕ
Конфигурация
Это таблица Dimensiuni
modelBuilder.Entity(entity =>
{
entity.ToTable("dimensiuni");
entity.HasKey(e => e.IdDimensiune);
entity.Property(e => e.IdDimensiune)
.HasColumnType("integer")
.HasColumnName("id_dimensiune")
.HasAnnotation("MySql:ValueGenerationStrategy", MySqlValueGenerationStrategy.IdentityColumn);
entity.Property(e => e.Lungime)
.HasColumnType("varchar")
.HasColumnName("lungime")
.HasMaxLength(4)
.IsRequired();
entity.Property(e => e.RecomandarePat)
.HasColumnType("varchar")
.HasColumnName("recomandare_pat")
.HasMaxLength(15);
entity.Property(e => e.Latime)
.HasColumnType("varchar")
.HasColumnName("latime")
.HasMaxLength(4)
.IsRequired();
entity.HasMany(e => e.DAsociereSeturi)
.WithOne(asoc => asoc.AsDimensiune)
.HasForeignKey(asoc => asoc.IdDimensiune)
.HasConstraintName("FK_Dimensiune_AsociereSeturi");
entity.HasMany(e => e.DProduseCuComenzi)
.WithOne(pc => pc.PcDimensiune)
.HasForeignKey(pc => pc.IdDimensiune)
.HasConstraintName("FK_Dimensiune_ProduseComenzi");
});
Это таблица Culori
modelBuilder.Entity(entity =>
{
entity.ToTable("culori");
entity.HasKey(e => e.IdCuloare);
entity.Property(e => e.IdCuloare)
.HasColumnType("integer")
.HasColumnName("id_culoare")
.HasAnnotation("MySql:ValueGenerationStrategy", MySqlValueGenerationStrategy.IdentityColumn);
entity.Property(e => e.NumeCuloare)
.HasColumnName("nume_culoare")
.HasColumnType("varchar")
.HasMaxLength(20)
.IsRequired();
entity.Property(e => e.IdCodCuloare)
.HasColumnName("id_cod_culoare")
.HasColumnType("integer")
.IsRequired();
entity.HasMany(e => e.CAsociereSeturi)
.WithOne(asoc => asoc.AsCuloare)
.HasForeignKey(asoc => asoc.IdCuloare)
.HasConstraintName("FK_Culoare_AsociereSeturi");
entity.HasMany(e => e.CProduseCuComenzi)
.WithOne(pc => pc.PcCuloare)
.HasForeignKey(pc => pc.IdCuloare)
.HasConstraintName("FK_Culoare_ProduseComenzoi")
.IsRequired();
});
Соответствующие части
// Culori with AsociereSeturi
entity.HasMany(e => e.CAsociereSeturi)
.WithOne(asoc => asoc.AsCuloare)
.HasForeignKey(asoc => asoc.IdCuloare)
.HasConstraintName("FK_Culoare_AsociereSeturi");
// Dimensiuni with AsociereSeturi
entity.HasMany(e => e.DAsociereSeturi)
.WithOne(asoc => asoc.AsDimensiune)
.HasForeignKey(asoc => asoc.IdDimensiune)
.HasConstraintName("FK_Dimensiune_AsociereSeturi");
Подробнее здесь: https://stackoverflow.com/questions/790 ... -left-join
EF Core Include() не выполняет LEFT JOIN ⇐ C#
Место общения программистов C#
1727255488
Anonymous
Проблема, с которой я столкнулся, заключается в следующем: мне нужно получить несколько свойств навигации, чтобы данные отображались на моем интерфейсе. Для их получения я использую .Include().
По умолчанию Include выполняет внутреннее соединение, я это понимаю. Я также читал, что если свойства навигации имеют значение NULL и тип столбца в базе данных может быть нулевым, будет выполнено LEFT JOIN. Мой запрос по-прежнему использует INNER JOIN, хотя оба моих столбца, FK, имеют значение NULL.
Это мой запрос
var listOfProductsOnSets = await productWithSetsRepository
.FindQueryable(asoc => asoc.IdSet == idSet)
.Include(c => c.AsCuloare)
.ThenInclude(cc => cc!.CodCuloare)
.Include(d => d.AsDimensiune)
.AsSplitQuery()
.ToListAsync();
Это мой класс:
public class AsociereSeturi
{
// Attributes
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int IdAsociereSet { get; init; }
// Foreign Keys
public int IdProdus { get; init; }
public Produse Produs { get; init; } = null!;
public int IdSet { get; init; }
public Seturi Set { get; init; } = null!;
public int? IdCuloare { get; init; }
public Culori? AsCuloare { get; init; }
public int? IdDimensiune { get; init; }
public Dimensiuni? AsDimensiune { get; init; }
public ICollection CombinatieSetPeComanda { get; }
}
А это мои журналы:
SELECT a.id_asociere_set, a.id_culoare, a.id_dimensiune, a.id_produs, a.id_set,
c.id_culoare, c.id_cod_culoare, c.nume_culoare,
d.id_dimensiune, d.latime, d.lungime, d.PerdeaEstePereche, d.recomandare_pat
FROM asociere_seturi AS a
INNER JOIN culori AS c ON a.id_culoare = c.id_culoare
INNER JOIN dimensiuni AS d ON a.id_dimensiune = d.id_dimensiune
WHERE a.id_set = @__idSet_0;
[b]РЕДАКТИРОВАНИЕ[/b]
Конфигурация
Это таблица Dimensiuni
modelBuilder.Entity(entity =>
{
entity.ToTable("dimensiuni");
entity.HasKey(e => e.IdDimensiune);
entity.Property(e => e.IdDimensiune)
.HasColumnType("integer")
.HasColumnName("id_dimensiune")
.HasAnnotation("MySql:ValueGenerationStrategy", MySqlValueGenerationStrategy.IdentityColumn);
entity.Property(e => e.Lungime)
.HasColumnType("varchar")
.HasColumnName("lungime")
.HasMaxLength(4)
.IsRequired();
entity.Property(e => e.RecomandarePat)
.HasColumnType("varchar")
.HasColumnName("recomandare_pat")
.HasMaxLength(15);
entity.Property(e => e.Latime)
.HasColumnType("varchar")
.HasColumnName("latime")
.HasMaxLength(4)
.IsRequired();
entity.HasMany(e => e.DAsociereSeturi)
.WithOne(asoc => asoc.AsDimensiune)
.HasForeignKey(asoc => asoc.IdDimensiune)
.HasConstraintName("FK_Dimensiune_AsociereSeturi");
entity.HasMany(e => e.DProduseCuComenzi)
.WithOne(pc => pc.PcDimensiune)
.HasForeignKey(pc => pc.IdDimensiune)
.HasConstraintName("FK_Dimensiune_ProduseComenzi");
});
Это таблица Culori
modelBuilder.Entity(entity =>
{
entity.ToTable("culori");
entity.HasKey(e => e.IdCuloare);
entity.Property(e => e.IdCuloare)
.HasColumnType("integer")
.HasColumnName("id_culoare")
.HasAnnotation("MySql:ValueGenerationStrategy", MySqlValueGenerationStrategy.IdentityColumn);
entity.Property(e => e.NumeCuloare)
.HasColumnName("nume_culoare")
.HasColumnType("varchar")
.HasMaxLength(20)
.IsRequired();
entity.Property(e => e.IdCodCuloare)
.HasColumnName("id_cod_culoare")
.HasColumnType("integer")
.IsRequired();
entity.HasMany(e => e.CAsociereSeturi)
.WithOne(asoc => asoc.AsCuloare)
.HasForeignKey(asoc => asoc.IdCuloare)
.HasConstraintName("FK_Culoare_AsociereSeturi");
entity.HasMany(e => e.CProduseCuComenzi)
.WithOne(pc => pc.PcCuloare)
.HasForeignKey(pc => pc.IdCuloare)
.HasConstraintName("FK_Culoare_ProduseComenzoi")
.IsRequired();
});
Соответствующие части
// Culori with AsociereSeturi
entity.HasMany(e => e.CAsociereSeturi)
.WithOne(asoc => asoc.AsCuloare)
.HasForeignKey(asoc => asoc.IdCuloare)
.HasConstraintName("FK_Culoare_AsociereSeturi");
// Dimensiuni with AsociereSeturi
entity.HasMany(e => e.DAsociereSeturi)
.WithOne(asoc => asoc.AsDimensiune)
.HasForeignKey(asoc => asoc.IdDimensiune)
.HasConstraintName("FK_Dimensiune_AsociereSeturi");
Подробнее здесь: [url]https://stackoverflow.com/questions/79020529/ef-core-include-not-doing-left-join[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия