Ejemplos de expresiones de grupo (Reporting Services)

En una región de datos, puede agrupar los datos por un solo campo o crear expresiones más complejas que identifiquen los datos por los que se debe realizar la agrupación. Las expresiones complejas incluyen referencias a varios campos o parámetros, instrucciones condicionales o código personalizado. Al definir un grupo para una región de datos, debe agregar estas expresiones a las propiedades del Grupo. Para obtener más información, vea Cómo agregar o eliminar un grupo en una región de datos (Reporting Services).

Para combinar dos o más grupos basados en expresiones de campo simples, agregue cada campo a la lista de expresiones de grupo en la definición de grupo.

Ejemplos de expresiones de grupo

En la siguiente tabla, se incluyen ejemplos de expresiones de grupo que se pueden usar para definir un grupo.

Descripción

Expresión

Agrupar por el campo Region.

=Fields!Region.Value

Agrupar por apellidos y nombre.

=Fields!LastName.Value

=Fields!FirstName.Value

Agrupar por la primera letra del apellido.

=Fields!LastName.Value.Substring(0,1)

Agrupar por parámetro, en función de la selección del usuario.

En este ejemplo, el parámetro GroupBy debe estar basado en una lista de valores disponibles que proporcione una opción válida por la que agrupar.

=Fields(Parameters!GroupBy.Value).Value

Agrupar por tres intervalos de edad independientes:

"Under 21", "Between 21 and 50" y "Over 50".

=IIF(First(Fields!Age.Value)<21,"Under 21",(IIF(First(Fields!Age.Value)>=21 AND First(Fields!Age.Value)<=50,"Between 21 and 50","Over 50")))

Agrupar por varios intervalos de edad. En este ejemplo se muestra código personalizado, escrito en .NET Visual Basic, que devuelve una cadena para los intervalos siguientes:

25 or Under

26 to 50

51 to 75

Over 75

=Code.GetRangeValueByAge(Fields!Age.Value)

Código personalizado:

Function GetRangeValueByAge(ByVal age As Integer) As String

Select Case age

Case 0 To 25

GetRangeValueByByAge = "25 or Under"

Case 26 To 50

GetRangeValueByByAge = "26 to 50"

Case 51 to 75

GetRangeValueByByAge = "51 to 75"

Case Else

GetRangeValueByByAge = "Over 75"

End Select

Return GetRangeValueByByAge

End Function

Para obtener más información acerca del código personalizado, vea Usar referencias de código personalizado en expresiones (Reporting Services).