APIs de ejemplo

https://jsonplaceholder.typicode.com/guide/

Vamos a consultar libros y artículos del nytimes. Aquí hay la lista de las apis:

https://developer.nytimes.com/apis

Yo me he creado una apikey: SFq0lnJwGzV4X8XyqV2kQvA3LgKAp3kN

Pero os podéis crear la vuestra.

Me gustaría que, desde el postman, accediéramos a la lista de los libros más vendidos y a los artículos de los tres últimos meses.

También podéis crear vuestra propia apikey y acceder, por ejemplo, a películas.

 

Ejercicio Pokemon

Vamos a crear una base de datos para almacenar mi colección de pokemons

Tendremos las siguientes tablas:

Categoría: id, nombre, descripcion

Pokemon: id, nombre,descripcion,tipo de energ´ía, categoría

Haremos un MVC que tenga un mantenimiento de la base de datos.

En el HomeController poned enlace al mantenimiento de categorías y al mantenimiento de pokemons.

Ejercicio controladores

using Microsoft.AspNetCore.Mvc;
using MVC01.Models;

namespace MVC01.Controllers
{
    public class CursoController : Controller
    {
        private readonly Contexto _context;

        public CursoController(Contexto context)
        {
            _context = context;
        }
        public IActionResult Index()
        {
            // Recuperar los datos de todos los cursos
            // Los vais a pasar a la vista
            // En la vista mostráis la información (id,nombre,descripcion)
            return View();
        }

        public IActionResult AddCurso()
            {
            // Llamar a una vista con un formulario
            // Para poner nombre y descripción
            return View();
        }
        public IActionResult NewCurso(Curso curso)
        {
            // Capturamos los datos del formulario
            // Y lo añadimos a la base de datos
            return View();
        }
    }
}

MVC + Consultas

Vamos a crear un controlador ConsultasController sobre la escuela. Tendrá las siguientes acciones:

Cursos

Nos mostrará la lista de cursos que tengan alumnos matriculados

Alumnos

Nos mostrará la lista de alumnos que estén matriculados en más de un curso

Direcciones
Nos mostrará la lista de alumnos que tengan más de una dirección

TotalPorCiudad
Nos mostrará el número de direcciones que tiene cada ciudad. Aquí tenemos una cadena y un número ¿Cómo lo haremos?

AlumnosCiudad
Nos mostrará los alumnos que sean de la ciudad que tiene más direcciones.

Como conectar

En program.cs

            // Add services to the container.
            builder.Services.AddControllersWithViews();
            // Añadimos la conexión al contexto
            builder.Services.AddDbContext<Contexto>(options =>
options.UseSqlServer("Data Source=.\\SQLEXPRESS;Initial Catalog=clase;Integrated Security=True;TrustServerCertificate=True"));
            var app = builder.Build();

En contexto.cs:

 public DbSet<Alumno> Alumnos { get; set; }
 public Contexto(DbContextOptions<Contexto> options) : base(options)
 {
 }