Razor Page只从存储过程返回一行项 - 如何返回所有行的结果?

问题描述 投票:0回答:1

我终于想出了如何使用我的存储过程中的数据生成剃刀页面。但只返回第一行或最后一行。

我尝试过使用nextresult(),但这没效果。我相信这只适用于我希望来自多个表的数据。我的存储过程与其他表有一些连接,但只有一个结果集。我只需要打印该结果集中的所有值。

当我在SSRS或SSMS中执行我的存储过程时,我得到多个值返回。这是我的SQL代码。

SELECT Movies.MovieTitle, Movies.MovieYear, Genres.GenreName 
FROM Movies 
INNER JOIN GenresMovies AS gm ON gm.MovieID = Movies.MovieID
INNER JOIN Genres ON Genres.GenreID = gm.GenreID
WHERE Genres.GenreID IN (SELECT Number FROM [fn_SplitInt](@GenreID, ','))

这是我的访问层,从反馈中重新更新。

using System;
using System.ComponentModel.DataAnnotations;
using System.Data;
using System.Data.SqlClient;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

namespace MyMovies.Models
{
    public class MovieDataAccessLayer
    {
        public List<Movies> GetMovieByMedia(byte? MediaID)
        {
            string connectionString = "Server=ServerName;Database=Movies;Trusted_Connection=True;MultipleActiveResultSets=true";
            var movies = new Movies();

            using (var con = new SqlConnection(connectionString))
            {
                using (var cmd = new SqlCommand("usp_MovieByMedia", con))
                {
                    cmd.Parameters.Add(new SqlParameter("@MediaID", SqlDbType.TinyInt) { Value = MediaID });
                    cmd.CommandType = CommandType.StoredProcedure;

                    con.Open();

                    using (var reader = cmd.ExecuteReader())
                    {
                        List<Movies> Movies = new List<Movies>();

                        while (reader.Read())
                        {
                            Movies movie = new Movies()
                            {
                                MovieTitle = reader["MovieTitle"].ToString(),
                                MovieYear = Convert.ToInt32(reader["MovieYear"])
                            };
                            Movies.Add(movie);
                        }
                    }

                    return Movies;
                }
            }
        }
    }
}

这是我执行存储过程的cshtml.cs,新更新。

namespace MyMovies.Pages.MovieDetails
{
    public class DetailsModel : PageModel
    {
        private readonly MyMovies.Models.MyMoviesContext _context;

        public DetailsModel(MyMovies.Models.MyMoviesContext context)
        {
            _context = context;
        }

        MovieDataAccessLayer objmovie = new MovieDataAccessLayer();
        public List <Movies> { get; set; }

        public async Task<IActionResult> OnGetAsync(byte? id)
        {
            if (id == null)
            {
                return NotFound();
            }

            Movies = objmovie.GetMovieByMedia(id);

            if (Movies == null)
            {
                return NotFound();
            }

            return Page();
        }
    }
}

最后,剃刀页面显示结果表,最新更新!

@page
@model MyMovies.Pages.MovieDetails.DetailsModel

@{
    ViewData["Title"] = "Details";
}

<table>
    <tr>
        <th>Movie Title</th>
        <th>Movie Year</th>
    </tr>
    @foreach (var item in Model.Movies)
    {
        <tr>
            <td class="col-sm-10">
                @Html.DisplayFor(Model => item.MovieTitle)
            </td>
            <td class="col-sm-10">
                @Html.DisplayFor(Model => item.MovieYear)
            </td>
        </tr>
    }
</table>

它返回第一个或最后一个行项。我该怎么办才能让它全部归还?如果我尝试做一个foreach循环,我将不得不制作我的电影课IEnumerable。但这样做,我无法弄清楚如何让我的存储过程工作。

c# asp.net tsql stored-procedures razor-pages
1个回答
0
投票
List<Movies> Movies = new List<Movies>();

while (reader.Read())
{
        Movies movie = new Movies()
        {
          MovieTitle = reader["MovieTitle"].ToString(),
          MovieYear = Convert.ToInt32(reader["MovieYear"])
        }

        Movies.Add(movie);
};

return Movies;

检查一下:

public List<Movies> GetMovieByMedia(byte? MediaID)
{
    string connectionString = "Server=ServerName;Database=Movies;Trusted_Connection=True;MultipleActiveResultSets=true";

    var movies = new Movies();

    using (var con = new SqlConnection(connectionString))
    {
        using (var cmd = new SqlCommand("usp_MovieByMedia", con))
        {
            cmd.Parameters.Add(new SqlParameter("@MediaID", SqlDbType.TinyInt) { Value = MediaID });
            cmd.CommandType = CommandType.StoredProcedure;

            con.Open();

            using (var reader = cmd.ExecuteReader())
            {
                List<Movies> Movies = new List<Movies>();

                while (reader.Read())
                {
                     Movies movie = new Movies()
                                    {
                                         MovieTitle = reader["MovieTitle"].ToString(),
                                         MovieYear = Convert.ToInt32(reader["MovieYear"])
                                    };
                     Movies.Add(movie);
                }
            }

            return Movies;
}

新代码

public List<Movies> Movies { get; set; }
Movies = objmovie.GetMovieByMedia(id);

剃刀页面的标记:

@using Movies
<table>
@foreach(var item in model.Movies)
{
    <tr>
        <th class="col-sm-10">
            @Html.DisplayNameFor(model => item.MovieTitle)
        </th>
        <th class="col-sm-10">
            @Html.DisplayNameFor(model => item.MovieYear)
        </th>
    </tr>
}
</table>

我希望它有效。我不能检查这个

© www.soinside.com 2019 - 2024. All rights reserved.