¿Qué hace addScalar?


El JavaDoc dice:

SQLQuery org.hibernate.SQLQuery.addScalar(String columnAlias, Type type)

Declare a scalar query result

Sé lo que executeScalar está en C#, pero este escalar y C# escalar parecen ser absolutamente diferentes.

Author: superM, 2013-03-13

3 answers

Esto está declarando 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 único Long. Si especifica varios escalares, el resultado volverá como una matriz de Object. Es similar a executeScalar excepto que funciona en columnas con nombre, y puede devolver un resultado compuesto.

 27
Author: Zutty,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2013-03-13 13:40:44

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 especifica:

the SQL query string
the columns and types to return

Esto devolverá matrices de objetos, pero ahora no utilizará ResultSetMetaData, sino que obtendrá explícitamente la columna ID, NAME y BIRTHDATE como, respectivamente, una Cadena Larga y una Corta del conjunto de resultados subyacente. Esto también significa que solo se devolverán estas tres columnas, aunque la consulta sea usando * y podría devolver más de las tres columnas listadas.

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, donde como el tipo de ID se especifica explícitamente.

Copiado de este.

 13
Author: Evan,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2014-03-22 03:31:15

addScalar es una información de tipo de retorno para una clave dada en la consulta SQL.

Ejemplo:

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

Si consulta el resultado, el resultado será una cadena u otros tipos si lo especifica.

 4
Author: Grigor Nazaryan,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2015-09-28 08:50:16