Mis cursos de Programación: hdeleon.net/cursos-premium/ La consulta del video: SELECT D.name as Department, E.name as Employee, E.salary as Salary FROM Employee as E INNER JOIN Department as D on D.id = E.departmentid WHERE E.salary IN (SELECT SWN.salary FROM (SELECT e.salary, ROW_NUMBER() OVER(ORDER BY salary DESC) AS number FROM ( SELECT DISTINCT e2.salary FROM Employee as e2 WHERE e2.departmentid= D.id ) as e WHERE e.departmentid= D.id ) as SWN WHERE SWN.number
Muy buen video, hallé una manera más sencilla de resolverlo usando DENSE_RANK y PARTITION BY pero basándome en tu solución: SELECT Department, Employee, Salary FROM (SELECT D.name AS Department, E.name AS Employee, E.salary AS Salary, DENSE_RANK() OVER (PARTITION BY D.name ORDER BY E.salary DESC) AS row_num FROM Employee AS E INNER JOIN Department AS D ON E.departmentId = D.id) AS top_3 WHERE top_3.row_num
Creo que nunca te había comentado Héctor, pero muchas gracias por todo tu contenido, te sigo desde que estaba en la prepa y ya terminé mi carrera este año y empecé a ejercer en mi primer trabajo, gracias por tanto, nunca se termina de aprender !
Excelente, también sería un group by por departamento y salario, posteriormente a ese resultado le haces un rownumber con partition, por departamento, y ya con eso ordenas los 3 primero, y un where solamente coges los 3 de cada país y ya, excelentes videos, el mejor canal 👌
No es difícil, más bien hay que entender los que nos piden, si se entiende bien lo que se pide seguramente se puede lograr, aún así gracias por el detalle del vídeo
hace tiempo yo tambien hubiera dichoque es es dificl, ya que no conocia mucho sobre sql. ahorita que lo vi la verdad esta facil pero ya por la experiencia. muy bien explicado espero mas videos de sql.
Pensé lo mismo jajaja, pero bueno así también se da visualización a subconsultas un poco más compejas, por si en algún momento trabajan con SnowFlake, o BigQuery y quieran usar una subconsulta para json, o tipos de datos semi estrucrurados, aunque soy fiel defensor de los CTE, esta forma también es buena para que personas que no se dediquen a SQL comos los Data Engineers y los Data Analyst puedan mejorar habilidades
Yo digo que para resolver ese tipo de problemas y hacer ese tipo de consultas se necesita muucha imaginación y orden de ideas, cosa que no que no tengo
Me acuerdo que en una entreviste hace unos años me tomaron exactamente el mismo el problema, nada mas cambiaba el nombre de las tablas, me habian dado 30 min para resolverla, me acuerdo que llegue justo, tambien habia usado el el row_number. Despues tambien me tomaron otra prueba que no pude pasar, habia que usar el group_concat que para ese entonces no tenia idea que era jajaj
Excelente contenido, tienes un curso donde enseñes SQL hasta nivel avanzado? Solo uso Sequalize y la verdad es que hay cosas que requieren meterle código SQL en algunas peticiones
hola! esta es mi solucion en sql server , esta bien ? porque es distinta pero obtengo el mismo resultado:select b.name Departament , a.name Employee, a.salary Salary from Employee a join Department b on a.departmentId=b.id where a.salary in (select distinct top 3 salary from Employee where departmentId= b.id order by salary desc) order by b.name desc
Lo bonito de la programación es que hay distintas formas de hacerlo select D.name as Department,E.name as Employee,T.Salary from ( SELECT distinct departmentid,salary, dense_rank() over (partition by departmentid order by salary desc) as salary_rank from Employee ) as T inner join Department D on D.Id = T.DepartmentID inner join Employee E on E.Salary =T.Salary where salary_rank
Excelente video. En lo personal nunca me e sentido comodo trabajando con alias en las tablas. Llevo 7 años trabajando con una base de datos donde las tablas llevan la nomeclatura mnt01, mnt02, mnt03... entre otras y tarde mucho en identificarlas como para todabía cambiarles el nombre xD
Hola Hector! Una duda, ¿por qué no usaste Row_number() over(partition by id order by e.salary) as number? ¿No es posible en la versión de MySQL? También me gustaría preguntarte porque no usaste WITH, ¿es más recomendable usar queries anidadas? Gracias!
Row_number() siempre te va a generar un número distinto por cada fila, aunque los valores se repitan. En este caso, para IT, hay 2 filas con valores iguales (85.000). Si usas Row_number(), el primer 85.000 tendría la posición 2 y el segundo la posición 3, por lo que no te serviría para calcular el top 3 (el tercer valor más alto para IT no repetido (70.000) quedaría fuera del TOP) En TSQL sí que se podría hacer como comentas, sólo que con Dense_rank() en lugar de Row_number(), y la query quedaría mucho más simplificada. Por otro lado, tengo entendido que por cuestiones de uso de memoria, es más recomendable usar subconsultas en lugar de CTEs (WITH)
Ahora como le pidieron a un conocido en una prueba técnica de una empresa local. Debes hacer el análisis de rendimiento con Notación big O de la consulta final. 👹
Seria posible crear el SQL query, usando puro JOIN, en lugar de usar IN ? He leido que usando JOINS, el performance de la consulta mejora muchisimo, especialmente si son miles de registros como usualmente pasa.
Seria de verificar, porque en la especificación sql anterior no estaba la sentencia JOIN y se hacia con el where (+) y el IN para los motores son al final varios WHERE AND pero mas legible (corríjanme si estoy mal)
Si, es posible resolverlo solo con Joins pero te vas a complicar la vida porque para ese problema en particular tendrias que usar dos inner joins y un left join. Es mucho mas simple con subconsultas, ahora si lo que te preocupa es el performance puedes aplicar common table expressions (cte) para encapsular fragmentos de codigo y luego reutilizarlo. No depende tanto de si se resuelve con joins o subqueries
Mis cursos de Programación: hdeleon.net/cursos-premium/
La consulta del video:
SELECT D.name as Department, E.name as Employee, E.salary as Salary
FROM Employee as E
INNER JOIN Department as D on D.id = E.departmentid
WHERE E.salary IN
(SELECT SWN.salary
FROM
(SELECT e.salary,
ROW_NUMBER() OVER(ORDER BY salary DESC) AS number
FROM (
SELECT DISTINCT e2.salary
FROM Employee as e2
WHERE e2.departmentid= D.id
) as e
WHERE e.departmentid= D.id
) as SWN
WHERE SWN.number
Sí, más vídeos de SQL avanzado, por favor!!! 🔥🤘🏻
Excelente idea esta de resolver esos casos más complejos, voto por que sigas con más ejemplos👏👏👏
se aprende mas xD q en cursos de 1 hora
Este tipo de contenidos deberían tener mucha más difusión sin duda, muchas gracias por tu esfuerzo !
Muy buen video, hallé una manera más sencilla de resolverlo usando DENSE_RANK y PARTITION BY pero basándome en tu solución:
SELECT Department, Employee, Salary
FROM
(SELECT D.name AS Department, E.name AS Employee, E.salary AS Salary,
DENSE_RANK() OVER (PARTITION BY D.name ORDER BY E.salary DESC) AS row_num
FROM Employee AS E
INNER JOIN Department AS D ON E.departmentId = D.id) AS top_3
WHERE top_3.row_num
Creo que nunca te había comentado Héctor, pero muchas gracias por todo tu contenido, te sigo desde que estaba en la prepa y ya terminé mi carrera este año y empecé a ejercer en mi primer trabajo, gracias por tanto, nunca se termina de aprender !
Excelente, también sería un group by por departamento y salario, posteriormente a ese resultado le haces un rownumber con partition, por departamento, y ya con eso ordenas los 3 primero, y un where solamente coges los 3 de cada país y ya, excelentes videos, el mejor canal 👌
No es difícil, más bien hay que entender los que nos piden, si se entiende bien lo que se pide seguramente se puede lograr, aún así gracias por el detalle del vídeo
hace tiempo yo tambien hubiera dichoque es es dificl, ya que no conocia mucho sobre sql. ahorita que lo vi la verdad esta facil pero ya por la experiencia. muy bien explicado espero mas videos de sql.
Gracias por el video, por favor sigue subiendo más videos sobre SQL.
Si, mas videos de SQL avanzado :) Chingon Hector, gracias.
Que buen video!
Sólo me quedó una duda: como quedaría la consulta si pudieramos utilizar la instrucción TOP/LIMIT ?
gracias por el tutorial amigo, mi mente exploto con todo lo que se puede hacer dentro de sql
te sigo desde Managua, Nicaragua
Wow siempre aprendo más de tus videos. Eres un crack. Muchas gracias por compartir tus conocimientos
Aún no veo el video y tengo la adrenalina como si fuera ver un estreno en el cine
Hermano saludos desde Venezuela, Excelente video. Gracias por compartir a la espera de nuevos conocimientos
No la hubiera podido resolver, ya aprendí mucho!!!! Gracias x el gran contenido!!!
Excelente amigo mas videos dedicados a consultas de menos a más y hasta las consultas mas chingonas!
Primera vez que te veo, muchas gracias, lo explicas muy bien.
Haz mas videos así, fue una buena prueba y la solución aún más
Buenas , excelente video, no defraudas, por mas videos como este. saludos
Gracias por compartir Amigo Metalero 👍👍
Excelente video como siempre explicaciones claras mas videos de este tipo hay pocos en youtube sobre todo en espanol
Sos demasiado pro bro!! saludos desde Argentina
Excelente, estaría bien que hicieras más videos de estos
Que buen vídeo, quedaría mucho mas limpio utilizando "With" para identificar fácilmente las tablas de las subconsultas
Pensé lo mismo jajaja, pero bueno así también se da visualización a subconsultas un poco más compejas, por si en algún momento trabajan con SnowFlake, o BigQuery y quieran usar una subconsulta para json, o tipos de datos semi estrucrurados, aunque soy fiel defensor de los CTE, esta forma también es buena para que personas que no se dediquen a SQL comos los Data Engineers y los Data Analyst puedan mejorar habilidades
de verdad que en ese ejercicio me hiciste recordar medio ciclo de curso
Si mas videos asi hector por favor😅
💪 excelente video lo tendré que ver otra vez 😅 , si más videos así de sql , súper bueno
mas videos de medio y anvanzado muchas gracias capo nuevo Subs ... !!
Muy buena forma de explicar y estas pruebas tecnicas esta geniales.
Recien lo veo,muy buen video,te lleva paso a paso
Excelente video, sigue subiendo ejercicios complejos de SQL por favor.
buen video, si se necesitas mas videos de sql avanzado
Muy bueno !
estan buenos sigue sacando videos de sql dificil
Gracias cabezón... Más vídeos de SQL difícil...😊
Excelente video y explicación, ¿puedes hacer una prueba técnica con tablas temporales ?
Gracias por compartir esa página, será que hay alguna similar para practicar C#?
Sólo vengo a agradecer porque me sirvió
Excelente, algunos mas por favor.
Excelente aporte Hector saludos🖥💡
Muy bueno! mas videos porfavor
excelente vídeo, realmente se necesitan contenido como este. me gustaría saber si existen páginas como estas pero con postgresql.
porfa un video de como elevar el nivel de SQL incluso podrias hacer un cursoen udemy
Yo digo que para resolver ese tipo de problemas y hacer ese tipo de consultas se necesita muucha imaginación y orden de ideas, cosa que no que no tengo
Muy buen video amigo , saludos.
Saludos HectorDLeon, Me puedes saludar en tu proximo subida de video
Sigue subiendo videos de este tipo.
Videazo crack!
Voy empezando en SQL y siento que si tuviera ese nivel de conocimiento ya podria hacer telequinesis jajaja
Que buen video pana, gracias por compartir tu conocimiento. 👍🏼
excelente, muchas gracias
Excelente video, cabezón. Gracias
Gracias por compartir tu conocimiento profe
Queremos másssss
Son necesarios ambos WHEREs? Me da la sensación de que con el de la subquery más interna basta, no?
Más videos!!!
Buen video Rapunzel
Buen video, estaria bueno mas de este tipo.
Excelente contenido bro!, Estuviera genial que crearas un curso de SQL, yo me apunto, Saludos!.
Pa cuando un cursito de microservicio con .NET? Saludos rey!!!
gracias, muy interesante!
Excelente contenido
Puedes compartir el documento de la prueba para practicar? Aún no ví la resolución quiero ver si lo puedo hacer solo. Por favor
Brutal. 👀😲
Un crack de verdad!!!
Profe ¿para trabajar en backend es necesario manejar el DCL o solo el DML y el DDL en el SQL?
Muchas gracias, aprendí bastante :D
Me acuerdo que en una entreviste hace unos años me tomaron exactamente el mismo el problema, nada mas cambiaba el nombre de las tablas, me habian dado 30 min para resolverla, me acuerdo que llegue justo, tambien habia usado el el row_number.
Despues tambien me tomaron otra prueba que no pude pasar, habia que usar el group_concat que para ese entonces no tenia idea que era jajaj
era para jr,semi sr o senior?
@@fernandoxd4601 seguro semi o sr
Excelente contenido, tienes un curso donde enseñes SQL hasta nivel avanzado? Solo uso Sequalize y la verdad es que hay cosas que requieren meterle código SQL en algunas peticiones
Videos de Store Procedures😊
Con los cursos que tienes en tu canal es posible llegar a ese nivel o tienes alguno de pago ?
me suscribo
hola! esta es mi solucion en sql server , esta bien ? porque es distinta pero obtengo el mismo resultado:select b.name Departament , a.name Employee, a.salary Salary
from Employee a join Department b on a.departmentId=b.id
where a.salary in (select distinct top 3 salary
from Employee
where departmentId= b.id
order by salary desc)
order by b.name desc
Excelente vídeo!!!
Lo bonito de la programación es que hay distintas formas de hacerlo select D.name as Department,E.name as Employee,T.Salary from (
SELECT distinct departmentid,salary, dense_rank() over (partition by departmentid order by salary desc) as salary_rank from Employee
) as T
inner join Department D on D.Id = T.DepartmentID
inner join Employee E on E.Salary =T.Salary
where salary_rank
SQL Avanzado !, please !!!
Excelente video. En lo personal nunca me e sentido comodo trabajando con alias en las tablas. Llevo 7 años trabajando con una base de datos donde las tablas llevan la nomeclatura mnt01, mnt02, mnt03... entre otras y tarde mucho en identificarlas como para todabía cambiarles el nombre xD
Hola Hector! Una duda, ¿por qué no usaste Row_number() over(partition by id order by e.salary) as number? ¿No es posible en la versión de MySQL?
También me gustaría preguntarte porque no usaste WITH, ¿es más recomendable usar queries anidadas?
Gracias!
Row_number() siempre te va a generar un número distinto por cada fila, aunque los valores se repitan.
En este caso, para IT, hay 2 filas con valores iguales (85.000). Si usas Row_number(), el primer 85.000 tendría la posición 2 y el segundo la posición 3, por lo que no te serviría para calcular el top 3 (el tercer valor más alto para IT no repetido (70.000) quedaría fuera del TOP)
En TSQL sí que se podría hacer como comentas, sólo que con Dense_rank() en lugar de Row_number(), y la query quedaría mucho más simplificada.
Por otro lado, tengo entendido que por cuestiones de uso de memoria, es más recomendable usar subconsultas en lugar de CTEs (WITH)
Cien mil likes compañero
¡Más videos de SQL! 🤘
ME GUSTO
Seria de gran ayuda puro SQL PRO avanzado
Yo lo hice en Oracle pero me da error cuando coloco el WHERE E.DEPARTMENTE = D.ID.
Que es un promedio ingeniering.
Genial
Sección dedicada a sql tienes?
curiosamente me vino asi en una prueba tecnica para practicante(trainee) de manera presencial con una base de datos real xD
WOW, te pasaste.
También se pudo hacer un group by directo desde la primer query que hiciste para poder quitar los salarios repetidos
Crack
que crack
Ahora como le pidieron a un conocido en una prueba técnica de una empresa local. Debes hacer el análisis de rendimiento con Notación big O de la consulta final. 👹
Seria posible crear el SQL query, usando puro JOIN, en lugar de usar IN ?
He leido que usando JOINS, el performance de la consulta mejora muchisimo, especialmente si son miles de registros como usualmente pasa.
Seria de verificar, porque en la especificación sql anterior no estaba la sentencia JOIN y se hacia con el where (+) y el IN para los motores son al final varios WHERE AND pero mas legible (corríjanme si estoy mal)
Si, es posible resolverlo solo con Joins pero te vas a complicar la vida porque para ese problema en particular tendrias que usar dos inner joins y un left join. Es mucho mas simple con subconsultas, ahora si lo que te preocupa es el performance puedes aplicar common table expressions (cte) para encapsular fragmentos de codigo y luego reutilizarlo. No depende tanto de si se resuelve con joins o subqueries
No entiendo por qué no se puede usar LIMIT si está disponible desde la versión 5.0 por lo menos...
Yo no puse las reglas.
Se te olvido decir que sampoo es el que te deja brillante el pelo cabezón
Más
Se ocupa un curso sobre SQL avanzado