Spark StructType 类型详解

  • StructType 是个case class,一般用于构建schema.
  • 因为是case class,所以使用的时候可以不用new关键字

构造函数

可以传入Seq,java的List,scala的Array,都是可以的~
在这里插入图片描述
还可以用无参的构造器,因为它有一个无参的构造器.

例子

  private val schema: StructType = StructType(List(
    StructField("name", DataTypes.StringType),
    StructField("age", DataTypes.IntegerType)
  ))

也可以是

  private val schema: StructType = StructType(Array(
    StructField("name", DataTypes.StringType),
    StructField("age", DataTypes.IntegerType)
  ))

还可以调用无参构造器,这么写

private val schema = (new StructType)
    .add(StructField("name", DataTypes.StringType))
    .add(StructField("age", DataTypes.IntegerType))

这个无参的构造器,调用了一个有参构造器.this里面是个方法,这个方法的返回值是Array类型,实际上就是无参构造器调用了主构造器

def this() = this(Array.empty[StructField])
case class StructType(fields: Array[StructField]) extends DataType with Seq[StructField] {}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鸭梨山大哎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值