Я не могу засеять данные в своем первом ASP. NET CORE APP - PullRequest
0 голосов

Я изучаю ASP. NET CORE, а также создаю свой первый веб-проект. Проект об аренде автомобилей. Я покажу, что было сделано с проектом и в чем моя проблема.

  1. Я реализую модели данных: 1

2 .Я пишу свойства CarCategory и т. Д.

namespace CarRentalSystem.Data.Models
{
    using System.Collections.Generic;

    using CarRentalSystem.Data.Common.Models;

    public class CarCategory : BaseDeletableModel<int>
    {
        public CarCategory()
        {
            this.SmallCars = new HashSet<SmallCarInfo>();
        }

        public string Name { get; set; }

        public string Title { get; set; }

        public string CarDescription { get; set; }

        public string CarImageUrl { get; set; }

        public virtual ICollection<SmallCarInfo> SmallCars { get; set; }
    }
}

3.Мой домашний контроллер:

namespace CarRentalSystem.Web.Controllers
{
    using System.Diagnostics;
    using System.Linq;

    using CarRentalSystem.Data;
    using CarRentalSystem.Services.Data;
    using CarRentalSystem.Web.ViewModels;
    using CarRentalSystem.Web.ViewModels.Administration.Dashboard;
    using CarRentalSystem.Web.ViewModels.Home;
    using Microsoft.AspNetCore.Mvc;

    public class HomeController : BaseController
    {
        private readonly ICategoriesService categoriesService;

        public HomeController(ICategoriesService categoriesService)
        {
            this.categoriesService = categoriesService;
        }

        public IActionResult Index()
        {
            var viewModel = new IndexViewModels
            {
                Categories = this.categoriesService.GetAll<IndexCategoryViewModel>(),
            };

            // var categories = this.db.CarCategories.Select(x => new IndexCategoryViewModel
            // {
            //    Title = x.Title,
            //    CarDescription = x.CarDescription,
            //    Name = x.Name,
            //    CarImageUrl = x.CarImageUrl,
            // }).ToList();

            // viewModel.Categories = categories;
            return this.View(viewModel);
        }

        public IActionResult Privacy()
        {
            return this.View();
        }

        [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
        public IActionResult Error()
        {
            return this.View(
                new ErrorViewModel { RequestId = Activity.Current?.Id ?? this.HttpContext.TraceIdentifier });
        }
    }
}

4. Я пишу на нем какой-то код. Я делаю сервисы и ViewModels

namespace CarRentalSystem.Web.ViewModels.Home
{
    using CarRentalSystem.Data.Models;
    using CarRentalSystem.Services.Mapping;

    public class IndexCategoryViewModel : IMapFrom<CarCategory>
    {
        public string Title { get; set; }

        public string CarDescription { get; set; }

        public string Name { get; set; }

        public string CarImageUrl { get; set; }

        public string Url => $"/c/{this.Name.Replace(' ', '-')}";
    }
}

namespace CarRentalSystem.Web.ViewModels.Home
{
    using System;
    using System.Collections.Generic;
    using System.Text;

    public class IndexViewModels
    {
        public IEnumerable<IndexCategoryViewModel> Categories { get; set; }
    }
}

namespace CarRentalSystem.Services.Data
{
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;

    using CarRentalSystem.Data.Common.Repositories;
    using CarRentalSystem.Data.Models;
    using CarRentalSystem.Services.Mapping;

    public class CategoriesService : ICategoriesService
    {
        private readonly IDeletableEntityRepository<CarCategory> categoriesRepository;

        public CategoriesService(IDeletableEntityRepository<CarCategory> categoriesRepository)
        {
            this.categoriesRepository = categoriesRepository;
        }

        public IEnumerable<T> GetAll<T>(int? count = null)
        {
            IQueryable<CarCategory> query =
                this.categoriesRepository.All();
            if (count.HasValue)
            {
                query = query.Take(count.Value);
            }

            return query.To<T>().ToList();
        }

        public T GetByName<T>(string name)
        {
            var category = this.categoriesRepository.All().Where(x => x.Name == name)
                    .To<T>().FirstOrDefault();

            return category;
        }
    }
}

5. Это сервис, который я использую, затем я делаю ПРОСМОТР, всю базу данных, а также сеялку для нужных мне головок, и моя домашняя страница готова

namespace CarRentalSystem.Data.Seeding
{
    using System;
    using System.Collections.Generic;
    using System.Threading.Tasks;

    using CarRentalSystem.Data.Models;
    using Microsoft.EntityFrameworkCore.Internal;

    public class CategoriesSeeder : ISeeder
    {
        public async Task SeedAsync(ApplicationDbContext dbContext, IServiceProvider serviceProvider)
        {
            if (dbContext.CarCategories.Any())
            {
                return;
            }

            var carCategories = new List<(string Name, string ImageUrl, string CarDescription)>
            {
                ("Small car", "https://cdn4.iconfinder.com/data/icons/car-silhouettes/1000/city-car-128.png",
                    "This is a compact car with 2/3 doors. Perfect for couples with small luggage."),
                ("Medium car", "https://cdn4.iconfinder.com/data/icons/car-silhouettes/1000/sedan-128.png",
                    "This is medium car with 4/5 doors. Perfect for small families with average luggage."),
                ("Minivan", "https://cdn4.iconfinder.com/data/icons/car-silhouettes/1000/minivan-128.png",
                    "This is a large car with 4/5 doors + extra seats. Perfect for large families with average luggage."),
                ("Minibus", "https://cdn4.iconfinder.com/data/icons/car-silhouettes/1000/van-128.png",
                    "This is a large car with 8+1 seats with big trunk. Perfect for large families or companies with a lot of luggage"),
            };

            foreach (var category in carCategories)
            {
                await dbContext.CarCategories.AddAsync(new CarCategory
                {
                    Name = category.Name,
                    Title = category.Name,
                    CarImageUrl = category.ImageUrl,
                    CarDescription = category.CarDescription,
                });
            }
        }
    }
}

@using CarRentalSystem.Common
@model CarRentalSystem.Web.ViewModels.Home.IndexViewModels
@{
    this.ViewData["Title"] = "Home Page";
}

<div class="text-center">
    <h1 class="display-4">Welcome to ElisCar</h1>
</div>

<div class="row">
@foreach (var category in Model.Categories)
{
    <div class="col-md-2 card m-auto" style="width: 18rem;">
        <img src="@category.CarImageUrl" width="100" class="card-img-top" alt="@category.Title">
        <div class="card-body">
            <h5 class="card-title">@category.Title</h5>
            @category.CarDescription
            <a href="@category.Url" class="btn btn-primary">Reservation</a>
        </div>
    </div>
}
</div>

Моя домашняя страница

6. После этого я хочу выбрать автомобили из категорий и получаю эту ошибку 3

7. Я знаю почему я получаю NullReferenceException, потому что у меня нет никаких данных, проблема в том, что я не могу их засеять. 1034 *

namespace CarRentalSystem.Web.ViewModels.Categories
{
    using System;
    using System.Collections.Generic;
    using System.Text;

    using CarRentalSystem.Data.Models;
    using CarRentalSystem.Services.Mapping;

    public class CarsViewModel : IMapFrom<CarCategory>
    {
        public string Title { get; set; }

        public string Name { get; set; }

        public string CarDescription { get; set; }

        public string CarImageUrl { get; set; }

        public IEnumerable<CarsListViewModel> CarDetails { get; set; }
    }
}

namespace CarRentalSystem.Web.ViewModels.Categories
{
    using System;
    using System.Collections.Generic;
    using System.Text;

    using CarRentalSystem.Data.Models;
    using CarRentalSystem.Services.Mapping;

    public class CarsListViewModel : IMapFrom<SmallCarInfo>
    {
        public string CarModel { get; set; }

        public string CarImage { get; set; }

        public int CarPricePerDay { get; set; }
    }
}

Базовая модель SmallCarsInfo 4

Теперь я пытаюсь добавить другие данные в базу данных, чтобы добавить марку автомобиля, цену и т. Д. c : 5

12.ВИД второго контроллера:

@using CarRentalSystem.Common
@model CarRentalSystem.Web.ViewModels.Categories.CarsViewModel
@{
    this.ViewData["Title"] = "Cars";
}

<h1 class="display-3">Hello!</h1>

<div class="row">
    @foreach (var details in Model.CarDetails)
    {
        <div class="card" style="width: 18rem;">
            <img src="@details.CarImage" class="card-img-top" alt="...">
            <div class="card-body">
                <h5 class="card-title">@details.CarModel</h5>
                <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
            </div>
            <ul class="list-group list-group-flush">
                <li class="list-group-item">@details.CarPricePerDay euro.</li>
                <li class="list-group-item">Dapibus ac facilisis in</li>
                <li class="list-group-item">Vestibulum at eros</li>
            </ul>
            <div class="card-body">
                <a href="#" class="card-link">Card link</a>
                <a href="#" class="card-link">Another link</a>
            </div>
        </div>
    }
</div>

13. Теперь поставил сеялки в StartUp для реализации их:

var seeders = new List<ISeeder>
                          {
                              new RolesSeeder(),
                              new SettingsSeeder(),
                              new CategoriesSeeder(),
                              new SmallCarsSeeder(),
                          };

14. И теперь, когда я запускаю проект, я получаю такую ​​ошибку: 7

15. Также я не получаю никаких данных в базу данных в SmallCar: 8

Первая сеялка работает, и на домашней странице все в порядке, но когда я нажимаю кнопку БРОНИРОВАНИЕ, у меня появляется исключение NullReferenceException, затем я кладу вторую сеялку, чтобы взять больше data и он не работает, я понятия не имею, что происходит.

1 Ответ

0 голосов
/ 05 мая 2020

Мне кажется, что внутри вашего SeedAsync метода, после foreach l oop добавления элементов в контекст БД, вам нужно вызвать dbContext.SaveChanges();, который «зафиксирует» добавленные элементы в фактическом база данных. В противном случае вы просто добавляете их в отслеживание в памяти. Попробуйте это и посмотрите, поможет ли это.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...