"version": "11.1.0",
Angular
net core
I have a sql view which use old project. Now i use that sql server view in asp.net zero project. I wrote customize repository like you reference. Then I run project. It is ok in server. The server reterive datas depend view query. But there is showing "An internal error occurred" message in frontend angular. I have alreay debug on server side. Serverside is ok. Please help me. You can see my codes.
I'm looking forward your answer.
application.shared layer
public class viewReservationFolio : CreationAuditedEntity<Guid>
{
......
}
public class InputSearch : PagedAndSortedResultRequestDto
{
....
}
EntityFrameworkCore Layer
public class ReservationRepository : BEZNgCoreRepositoryBase<viewReservationFolio, Guid>, IReservationRepository
{
private readonly IActiveTransactionProvider _transactionProvider;
public ReservationRepository(IDbContextProvider<BEZNgCoreDbContext> dbContextProvider, IActiveTransactionProvider transactionProvider)
: base(dbContextProvider)
{
_transactionProvider = transactionProvider;
}
public async Task<List<viewReservationFolio>> GetViewReservationFolio(InputSearch input)
{
var sqlText = QueryText(input);
var result = new List<viewReservationFolio>();
if ((input.IsCompany == false && input.IsGroup == false) || (input.IsCompany == true && input.IsGroup == true && input.IsCancel == false && input.IsPending == false && input.IsNoShow == false &&
input.IsReservation == false && input.IsHouse == false && input.IsCheckOut == false))
{
result = new List<viewReservationFolio>();
}
else
{
await EnsureConnectionOpenAsync();
var arams = GetParameterValue(input);
using (var command = CreateCommand(sqlText, CommandType.Text, arams))
{
using (var dataReader = await command.ExecuteReaderAsync())
{
try
{
while (await dataReader.ReadAsync())
{
viewReservationFolio v = new viewReservationFolio();
........
result.Add(v);
}
dataReader.Close();
}
catch (Exception ex)
{
throw ex;
}
}
}
await EnsureConnectionCloseAsync();
}
return result;
}
Core Layer
public interface IReservationRepository : IRepository<viewReservationFolio, Guid>
{
Task<List<viewReservationFolio>> GetViewReservationFolio(InputSearch input);
}
Application Layer
[AbpAuthorize(AppPermissions.Pages_Reservations)]
public class ReservationAppService : BEZNgCoreAppServiceBase, IReservationAppService
{
private readonly IApplicationLanguageManager _applicationLanguageManager;
..........................
public ReservationAppService(
IApplicationLanguageManager applicationLanguageManager,
...................)
{
_applicationLanguageManager = applicationLanguageManager;
.....
}
public async Task<List<StayDateDto>> GetStayDate()
{
}
public async Task<PagedResultDto<GetReservationFolioDto>> GetViewReservationFolioToday(InputSearch input)
{
var vw = _reservationRepository.GetViewReservationFolio(input);
var pagedAndFilteredRegistration = vw.Result.AsQueryable();
pagedAndFilteredRegistration=pagedAndFilteredRegistration.OrderBy(input.Sorting ?? "CheckInDate,DocNo asc").PageBy(input);
var totalCount = pagedAndFilteredRegistration.Count();
var dbList = pagedAndFilteredRegistration.ToList();
var results = new List<GetReservationFolioDto>();
foreach (var o in dbList)
{
var res = new GetReservationFolioDto()
{
GetViewResFolio = ObjectMapper.Map<viewReservationFolioDto>(o)
};
results.Add(res);
}
return new PagedResultDto<GetReservationFolioDto>(
totalCount,
results
);
}
Note: results list incluse datas.
Log File
INFO 2022-05-23 01:20:11,930 [orker] osoft.EntityFrameworkCore.Infrastructure - Entity Framework Core 6.0.0 initialized 'BEZNgCoreDbContext' using provider 'Microsoft.En
ERROR 2022-05-23 01:20:21,678 [orker] Mvc.ExceptionHandling.AbpExceptionFilter - This SqlTransaction has completed; it is no longer usable.
System.InvalidOperationException: This SqlTransaction has completed; it is no longer usable.
INFO 2022-05-23 01:20:21,691 [orker] c.Infrastructure.ControllerActionInvoker - Executed action BEZNgCore.Reservations.ReservationAppService.GetViewReservationFolioToday (BEZNgCore.Application) in 11899.6915ms
INFO 2022-05-23 01:20:21,691 [orker] ft.AspNetCore.Routing.EndpointMiddleware - Executed endpoint 'BEZNgCore.Reservations.ReservationAppService.GetViewReservationFolioToday (BEZNgCore.Application)'
INFO 2022-05-23 01:20:21,691 [orker] Microsoft.AspNetCore.Hosting.Diagnostics - Request finished HTTP/2 GET https://localhost:port/api/services/app/Reservation/GetViewReservationFolioToday?Filter=&StayDate=default&IsReservation=true&IsHouse=true&IsCheckOut=true&IsCompany=true&IsGroup=true&FirstName=&LastName=&RoomNo=&FolioNo=&CompanyName=&GroupName=&VoucherNo=&TelNo=&MobileNo=&Email=&Passport=&RateCode=&LoyaltyNo=&AccNo=&PostalCode=&GDS=&Group1Key=&Group2Key=&Group3Key=&Group4Key=&RateTypekey=&Sorting=&SkipCount=0&MaxResultCount=10 - - - 500 207 application/json;+charset=utf-8 11953.9042ms
INFO 2022-05-23 01:20:23,974 [orker] osoft.EntityFrameworkCore.Infrastructure - Entity Framework Core 6.0.0 initialized 'BEZNgCoreDbContext' using provider 'Microsoft.EntityFrameworkCore.SqlServer:6.0.0' with options: None
Frontend
https://localhost:port/api/services/app/Reservation/GetViewReservationFolioToday?..
{"result":null,"targetUrl":null,"success":false,"error":{"code":0,"message":"An internal error occurred during your request!","details":null,"validationErrors":null},"unAuthorizedRequest":false,"__abp":true}
9 Answer(s)
-
0
Hi @billyteng
Your code seems fine at first look. Is it possible to share your project via email (info@aspnetzero.com) ? We can check it locally for you.
Thanks
-
0
HI ismcagdas
I have already sent project file to your reference email. Please check it.Thanks
-
0
Hi @billyteng
Thanks, we got the project.
I have requested the view's script via email. -
0
HI ismcagdas
Our view is bit complicated and need many table to create.
I have already sent. Please check.Thanks
-
0
Hi @billyteng
We acn continue via email for this problem. I requested additional resources.
Thanks,
-
0
HI ismcagdas
I have already sent db file to your reference email. Please check it.
Thanks
-
0
Hi @billyteng
Could you add below attribute to your GetViewReservationFolioToday method ? It worked for me.
[UnitOfWork(isTransactional: false)]
The final method will be like this;
[UnitOfWork(isTransactional: false)] public async Task> GetViewReservationFolioToday(InputSearch input) { // method content... }
-
0
Hi @ismcagdas
It's ok now.
Thanks million.
Great team and support.Thanks all
-
0
Thanks :)