我终于想出了如何使用我的存储过程中的数据生成剃刀页面。但只返回第一行或最后一行。
我尝试过使用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
。但这样做,我无法弄清楚如何让我的存储过程工作。
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>
我希望它有效。我不能检查这个