

# AWS Glue Scala DynamicRecord クラス
<a name="glue-etl-scala-apis-glue-dynamicrecord-class"></a>

**Topics**
+ [def addField](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-addField)
+ [def dropField](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-dropField)
+ [def setError](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-setError)
+ [def isError](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-isError)
+ [def getError](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-getError)
+ [def clearError](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-clearError)
+ [def write](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-write)
+ [def readFields](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-readFields)
+ [def clone](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-clone)
+ [def schema](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-schema)
+ [def getRoot](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-getRoot)
+ [def toJson](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-toJson)
+ [def getFieldNode](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-getFieldNode)
+ [def getField](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-getField)
+ [def hashCode](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-hashCode)
+ [def equals](#glue-etl-scala-apis-glue-dynamicrecord-class-defs-equals)
+ [DynamicRecord オブジェクト](#glue-etl-scala-apis-glue-dynamicrecord-object)
+ [RecordTraverser 特性](#glue-etl-scala-apis-glue-recordtraverser-trait)

**パッケージ: com.amazonaws.services.glue**

```
class DynamicRecord extends Serializable with Writable with Cloneable
```

`DynamicRecord` は、処理対象のデータセット内のデータ行を表す自己記述型のデータ構造体です。自己記述型とは、`DynamicRecord` が表す行のスキーマを、レコード自体を検査することで取得できるという意味です。`DynamicRecord` は Apache Spark の `Row` に似ています。

## def addField
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-addField"></a>

```
def addField( path : String,
              dynamicNode : DynamicNode
            ) : Unit
```

指定したパスに [DynamicNode](glue-etl-scala-apis-glue-types-dynamicnode.md) を追加します。
+ `path` - 追加するフィールドのパス。
+ `dynamicNode` - 指定したパスに追加する [DynamicNode](glue-etl-scala-apis-glue-types-dynamicnode.md)。

## def dropField
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-dropField"></a>

```
 def dropField(path: String, underRename: Boolean = false): Option[DynamicNode]
```

指定したパスに配列がない場合は、指定したパスから [DynamicNode](glue-etl-scala-apis-glue-types-dynamicnode.md) を削除し、削除したノードを返します。
+ `path` - 削除するフィールドへのパス。
+ `underRename``dropField` – 名前変更の変換の一部として が呼び出された場合は true、それ以外の場合は false (デフォルトは false)。

`scala.Option Option` ([DynamicNode](glue-etl-scala-apis-glue-types-dynamicnode.md)) を返します。

## def setError
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-setError"></a>

```
def setError( error : Error )
```

`error` パラメータの指定に従って、このレコードをエラーレコードとして設定します。

戻り値は `DynamicRecord`。

## def isError
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-isError"></a>

```
def isError
```

このレコードがエラーレコードであるかどうかを確認します。

## def getError
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-getError"></a>

```
def getError
```

レコードがエラーレコードである場合、`Error` を受け取ります。このレコードがエラーレコードである場合は `scala.Some Some` (エラー) を返し、それ以外の場合は `scala.None` を返します。

## def clearError
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-clearError"></a>

```
def clearError
```

`Error` を `scala.None.None` に設定します。

## def write
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-write"></a>

```
override def write( out : DataOutput ) : Unit 
```



## def readFields
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-readFields"></a>

```
override def readFields( in : DataInput ) : Unit 
```



## def clone
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-clone"></a>

```
override def clone : DynamicRecord 
```

このレコードを新しい `DynamicRecord` に複製し、返します。

## def schema
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-schema"></a>

```
def schema
```

レコードを検査して `Schema` を取得します。

## def getRoot
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-getRoot"></a>

```
def getRoot : ObjectNode 
```

レコードのルート `ObjectNode` を取得します。

## def toJson
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-toJson"></a>

```
def toJson : String 
```

レコードの JSON 文字列を取得します。

## def getFieldNode
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-getFieldNode"></a>

```
def getFieldNode( path : String ) : Option[DynamicNode] 
```

`DynamicNode` のオプションとして指定した `path` でフィールドの値を取得します。

フィールドが存在する場合は `scala.Some Some`([DynamicNode](glue-etl-scala-apis-glue-types-dynamicnode.md)) を返し、それ以外の場合は `scala.None.None` を返します。

## def getField
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-getField"></a>

```
def getField( path : String ) : Option[Any] 
```

`DynamicNode` のオプションとして指定した `path` でフィールドの値を取得します。

`scala.Some Some` (値) を返します。

## def hashCode
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-hashCode"></a>

```
override def hashCode : Int 
```



## def equals
<a name="glue-etl-scala-apis-glue-dynamicrecord-class-defs-equals"></a>

```
override def equals( other : Any )
```



## DynamicRecord オブジェクト
<a name="glue-etl-scala-apis-glue-dynamicrecord-object"></a>

```
object DynamicRecord
```

### def apply
<a name="glue-etl-scala-apis-glue-dynamicrecord-object-defs-apply"></a>

```
def apply( row : Row,
           schema : SparkStructType )
```

メソッドを適用して Apache Spark SQL `Row` を [DynamicRecord](#glue-etl-scala-apis-glue-dynamicrecord-class) に変換します。
+ `row` – Spark SQL `Row`。
+ `schema` – 行の `Schema`。

戻り値は `DynamicRecord`。

## RecordTraverser 特性
<a name="glue-etl-scala-apis-glue-recordtraverser-trait"></a>

```
trait RecordTraverser {
  def nullValue(): Unit
  def byteValue(value: Byte): Unit
  def binaryValue(value: Array[Byte]): Unit
  def booleanValue(value: Boolean): Unit
  def shortValue(value: Short) : Unit
  def intValue(value: Int) : Unit
  def longValue(value: Long) : Unit
  def floatValue(value: Float): Unit
  def doubleValue(value: Double): Unit
  def decimalValue(value: BigDecimal): Unit
  def stringValue(value: String): Unit
  def dateValue(value: Date): Unit
  def timestampValue(value: Timestamp): Unit
  def objectStart(length: Int): Unit
  def objectKey(key: String): Unit
  def objectEnd(): Unit
  def mapStart(length: Int): Unit
  def mapKey(key: String): Unit
  def mapEnd(): Unit
  def arrayStart(length: Int): Unit
  def arrayEnd(): Unit
}
```