Saltar al contenido

¿Qué hace addScalar?

Si encuentras algún detalle que no entiendes puedes comentarlo y haremos todo lo necesario de ayudarte rápidamente.

Solución:

Esto declara que desea que el resultado de la consulta devuelva objetos para columnas individuales con nombre, en lugar de entidades. Por ejemplo

createSQLQuery("SELECT COUNT(*) AS c FROM Users").addScalar("c").uniqueResult()

devolverá un solo Long. Si especifica múltiples escalares, el resultado volverá como un array de Object. Es similar a executeScalar excepto que funciona en columnas con nombre y puede devolver un resultado compuesto.

Para evitar la sobrecarga de usar ResultSetMetadata, o simplemente para ser más explícito en lo que se devuelve, se puede usar addScalar():

session.createSQLQuery("SELECT * FROM CATS")
.addScalar("ID", Hibernate.LONG)
.addScalar("NAME", Hibernate.STRING)
.addScalar("BIRTHDATE", Hibernate.DATE)

Esta consulta especificó:

the SQL query string
the columns and types to return

Esto devolverá matrices de objetos, pero ahora no usará ResultSetMetadata, sino que obtendrá explícitamente la columna ID, NOMBRE y FECHA DE NACIMIENTO como Long, String y Short, respectivamente, del conjunto de resultados subyacente. Esto también significa que solo se devolverán estas tres columnas, aunque la consulta utilice * y podría devolver más de las tres columnas enumeradas.

Es posible omitir la información de tipo para todos o algunos de los escalares.

session.createSQLQuery("SELECT * FROM CATS")
.addScalar("ID", Hibernate.LONG)
.addScalar("NAME")
.addScalar("BIRTHDATE")

Esta es esencialmente la misma consulta que antes, pero ahora ResultSetMetaData se usa para determinar el tipo de NOMBRE y FECHA DE NACIMIENTO, mientras que el tipo de ID se especifica explícitamente.

copiado de esto.

addScalar es una información de returnType para un determinado key en consulta SQL.

Ejemplo:

Query a = new SqlQuery("Select username as un from users where ...");
a.addScalar("un", String);

Si consulta por resultado, el resultado será Cadena u otros tipos si lo especifica.

valoraciones y reseñas

Si para ti ha resultado de provecho nuestro post, sería de mucha ayuda si lo compartes con el resto juniors así contrubuyes a difundir esta información.

¡Haz clic para puntuar esta entrada!
(Votos: 0 Promedio: 0)



Utiliza Nuestro Buscador

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *