--- layout: doc_page --- # Transforming Dimension Values The following JSON fields can be used in a query to operate on dimension values. ## DimensionSpec `DimensionSpec`s define how dimension values get transformed prior to aggregation. ### DefaultDimensionSpec Returns dimension values as is and optionally renames the dimension. ```json { "type" : "default", "dimension" : , "outputName": } ``` ### ExtractionDimensionSpec Returns dimension values transformed using the given [DimExtractionFn](#toc_3) ```json { "type" : "extraction", "dimension" : , "outputName" : , "dimExtractionFn" : } ``` ## DimExtractionFn `DimExtractionFn`s define the transformation applied to each dimension value ### RegexDimExtractionFn Returns the first group matched by the given regular expression. If there is no match it returns the dimension value as is. ```json { "type" : "regex", "expr", } ``` ### PartialDimExtractionFn Returns the dimension value as is if there is a match, otherwise returns null. ```json { "type" : "partial", "expr", } ``` ### SearchQuerySpecDimExtractionFn Returns the dimension value as is if the given [SearchQuerySpec](SearchQuerySpec.html) matches, otherwise returns null. ```json { "type" : "searchQuery", "query" : } ``` ### TimeDimExtractionFn Parses dimension values as timestamps using the given input format, and returns them formatted using the given output format. Time formats follow the [com.ibm.icu.text.SimpleDateFormat](http://icu-project.org/apiref/icu4j/com/ibm/icu/text/SimpleDateFormat.html) format ```json { "type" : "time", "timeFormat" : , "resultFormat" : } ``` ### JavascriptDimExtractionFn Returns the dimension value as transformed by the given JavaScript function. Example ```json { "type" : "javascript", "function" : "function(str) { return str.substr(0, 3); }" }