

# Funções de data
<a name="s3-select-sql-reference-date"></a>

**Importante**  
O Amazon S3 Select não está mais disponível para novos clientes. Os clientes existentes do Amazon S3 Select podem continuar usando o recurso normalmente. [Saiba mais](https://aws.amazon.com/blogs/storage/how-to-optimize-querying-your-data-in-amazon-s3/) 

O Amazon S3 Select é compatível com as seguintes funções de data.

**Topics**
+ [DATE\_ADD](#s3-select-sql-reference-date-add)
+ [DATE\_DIFF](#s3-select-sql-reference-date-diff)
+ [EXTRACT](#s3-select-sql-reference-extract)
+ [TO\_STRING](#s3-select-sql-reference-to-string)
+ [TO\_TIMESTAMP](#s3-select-sql-reference-to-timestamp)
+ [UTCNOW](#s3-select-sql-reference-utcnow)

## DATE\_ADD
<a name="s3-select-sql-reference-date-add"></a>

Dada uma parte da data, uma quantidade e um carimbo de data/hora, `DATE_ADD` retorna um carimbo de data/hora atualizado, alterando a parte da data pela quantidade.

### Sintaxe
<a name="s3-select-sql-reference-date-add-syntax"></a>

```
DATE_ADD( {{date_part}}, {{quantity}}, {{timestamp}} )
```

### Parâmetros
<a name="s3-select-sql-reference-date-add-parameters"></a>

*`{{date_part}}`*   
Especifica que parte da data deve ser modificada. Pode ser uma das partes a seguir:  
+ year
+ mês
+ dia
+ hora
+ minuto
+ segundos

 *`{{quantity}}`*   
O valor a ser aplicado a um carimbo de data/hora atualizado. Os valores positivos para a `{{quantity}}` são adicionados à date\_part do carimbo de data/hora e os valores negativos são subtraídos.

 *`{{timestamp}}`*   
O carimbo de data/hora de destino no qual a função opera.

### Exemplos
<a name="s3-select-sql-reference-date-add-examples"></a>

```
DATE_ADD(year, 5, `2010-01-01T`)                -- 2015-01-01 (equivalent to 2015-01-01T)
DATE_ADD(month, 1, `2010T`)                     -- 2010-02T (result will add precision as necessary)
DATE_ADD(month, 13, `2010T`)                    -- 2011-02T
DATE_ADD(day, -1, `2017-01-10T`)                -- 2017-01-09 (equivalent to 2017-01-09T)
DATE_ADD(hour, 1, `2017T`)                      -- 2017-01-01T01:00-00:00
DATE_ADD(hour, 1, `2017-01-02T03:04Z`)          -- 2017-01-02T04:04Z
DATE_ADD(minute, 1, `2017-01-02T03:04:05.006Z`) -- 2017-01-02T03:05:05.006Z
DATE_ADD(second, 1, `2017-01-02T03:04:05.006Z`) -- 2017-01-02T03:04:06.006Z
```

## DATE\_DIFF
<a name="s3-select-sql-reference-date-diff"></a>

Dada uma parte da data e dois carimbos de data/hora válidos, `DATE_DIFF` retorna a diferença nas partes da data. O valor de retorno é um inteiro negativo quando o valor `{{date_part}}` do `{{timestamp1}}` for maior que o valor `{{date_part}}` do `{{timestamp2}}`. O valor de retorno é um inteiro positivo quando o valor `{{date_part}}` do `{{timestamp1}}` for menor que o valor `{{date_part}}` do `{{timestamp2}}`.

### Sintaxe
<a name="s3-select-sql-reference-date-diff-syntax"></a>

```
DATE_DIFF( {{date_part}}, {{timestamp1}}, {{timestamp2}} )
```

### Parâmetros
<a name="s3-select-sql-reference-date-diff-parameters"></a>

 *{{`date_part`}}*   
Especifica que parte dos carimbos de data/hora deve ser comparada. Para a definição de `date_part`, consulte [DATE\_ADD](#s3-select-sql-reference-date-add).

 *{{`timestamp1`}}*   
O primeiro carimbo de data/hora a ser comparado.

 *{{`timestamp2`}}*   
O segundo carimbo de data/hora a ser comparado.

### Exemplos
<a name="s3-select-sql-reference-date-diff-examples"></a>

```
DATE_DIFF(year, `2010-01-01T`, `2011-01-01T`)            -- 1
DATE_DIFF(year, `2010T`, `2010-05T`)                     -- 4 (2010T is equivalent to 2010-01-01T00:00:00.000Z)
DATE_DIFF(month, `2010T`, `2011T`)                       -- 12
DATE_DIFF(month, `2011T`, `2010T`)                       -- -12
DATE_DIFF(day, `2010-01-01T23:00`, `2010-01-02T01:00`) -- 0 (need to be at least 24h apart to be 1 day apart)
```

## EXTRACT
<a name="s3-select-sql-reference-extract"></a>

Dada uma parte da data e um carimbo de data/hora, `EXTRACT` retorna o valor da parte da data do carimbo de data/hora.

### Sintaxe
<a name="s3-select-sql-reference-extract-syntax"></a>

```
EXTRACT( {{date_part}} FROM {{timestamp}} )
```

### Parâmetros
<a name="s3-select-sql-reference-extract-parameters"></a>

 *{{`date_part`}}*   
Especifica que parte dos carimbos de data/hora deve ser extraída. Pode ser uma das partes a seguir:  
+ `YEAR`
+ `MONTH`
+ `DAY`
+ `HOUR`
+ `MINUTE`
+ `SECOND`
+ `TIMEZONE_HOUR`
+ `TIMEZONE_MINUTE`

 *{{`timestamp`}}*   
O carimbo de data/hora de destino no qual a função opera.

### Exemplos
<a name="s3-select-sql-reference-extract-examples"></a>

```
EXTRACT(YEAR FROM `2010-01-01T`)                           -- 2010
EXTRACT(MONTH FROM `2010T`)                                -- 1 (equivalent to 2010-01-01T00:00:00.000Z)
EXTRACT(MONTH FROM `2010-10T`)                             -- 10
EXTRACT(HOUR FROM `2017-01-02T03:04:05+07:08`)             -- 3
EXTRACT(MINUTE FROM `2017-01-02T03:04:05+07:08`)           -- 4
EXTRACT(TIMEZONE_HOUR FROM `2017-01-02T03:04:05+07:08`)    -- 7
EXTRACT(TIMEZONE_MINUTE FROM `2017-01-02T03:04:05+07:08`)  -- 8
```

## TO\_STRING
<a name="s3-select-sql-reference-to-string"></a>

Dado um carimbo de data/hora e um padrão de formato, `TO_STRING` retorna uma representação de string do carimbo de data/hora no formato especificado.

### Sintaxe
<a name="s3-select-sql-reference-size-syntax"></a>

```
TO_STRING ( {{timestamp}} {{time_format_pattern}} )
```

### Parâmetros
<a name="s3-select-sql-reference-size-parameters"></a>

 *`{{timestamp}}`*   
O carimbo de data/hora de destino no qual a função opera.

 *`{{time_format_pattern}}`*   
Uma string que possui as seguintes interpretações de caracteres especiais:      
[See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/AmazonS3/latest/userguide/s3-select-sql-reference-date.html)

### Exemplos
<a name="s3-select-sql-reference-size-examples"></a>

```
TO_STRING(`1969-07-20T20:18Z`,  'MMMM d, y')                    -- "July 20, 1969"
TO_STRING(`1969-07-20T20:18Z`, 'MMM d, yyyy')                   -- "Jul 20, 1969"
TO_STRING(`1969-07-20T20:18Z`, 'M-d-yy')                        -- "7-20-69"
TO_STRING(`1969-07-20T20:18Z`, 'MM-d-y')                        -- "07-20-1969"
TO_STRING(`1969-07-20T20:18Z`, 'MMMM d, y h:m a')               -- "July 20, 1969 8:18 PM"
TO_STRING(`1969-07-20T20:18Z`, 'y-MM-dd''T''H:m:ssX')           -- "1969-07-20T20:18:00Z"
TO_STRING(`1969-07-20T20:18+08:00Z`, 'y-MM-dd''T''H:m:ssX')     -- "1969-07-20T20:18:00Z"
TO_STRING(`1969-07-20T20:18+08:00`, 'y-MM-dd''T''H:m:ssXXXX')   -- "1969-07-20T20:18:00+0800"
TO_STRING(`1969-07-20T20:18+08:00`, 'y-MM-dd''T''H:m:ssXXXXX')  -- "1969-07-20T20:18:00+08:00"
```

## TO\_TIMESTAMP
<a name="s3-select-sql-reference-to-timestamp"></a>

Dada uma string, `TO_TIMESTAMP` converte-se em um carimbo de data/hora. `TO_TIMESTAMP` é a operação inversa de `TO_STRING`.

### Sintaxe
<a name="s3-select-sql-reference-to-timestamp-syntax"></a>

```
TO_TIMESTAMP ( {{string}} )
```

### Parâmetros
<a name="s3-select-sql-reference-to-timestamp-parameters"></a>

 *`{{string}}`*   
A string de destino na qual a função opera.

### Exemplos
<a name="s3-select-sql-reference-to-timestamp-examples"></a>

```
TO_TIMESTAMP('2007T')                         -- `2007T`
TO_TIMESTAMP('2007-02-23T12:14:33.079-08:00') -- `2007-02-23T12:14:33.079-08:00`
```

## UTCNOW
<a name="s3-select-sql-reference-utcnow"></a>

`UTCNOW` retorna o tempo atual em UTC como um carimbo de data/hora.

### Sintaxe
<a name="s3-select-sql-reference-utcnow-syntax"></a>

```
UTCNOW()
```

### Parâmetros
<a name="s3-select-sql-reference-utcnow-parameters"></a>

`UTCNOW` não aceita parâmetros.

### Exemplos
<a name="s3-select-sql-reference-utcnow-examples"></a>

```
UTCNOW() -- 2017-10-13T16:02:11.123Z
```