spark内置数据类型

在用scala编写spark的时候,假如我现在需要将我spark读的数据源的字段,做一个类型转换,因

为需求中要拼接出sql的create table语句,需要每个字段的sql中的类型,那么就需要去和sparksql

中的内置数据类型去比对。

写spark的时候,创建df后用schema算子得到了structField类,查看了源码以后,发现

这个样例类的三个参数:name、dataType、nullable、(metadata)

发现第二个参数是这个包下的

于是查阅资料 发现一共有这些参数:

复制代码
整数类型:

IntegerType 或 IntType: 32 位有符号整数。
LongType: 64 位有符号整数。
ShortType: 16 位有符号整数。
ByteType: 8 位有符号整数。
浮点数类型:

FloatType: 单精度浮点数。
DoubleType: 双精度浮点数。
十进制类型:

DecimalType: 固定精度和固定规模的十进制数。
布尔类型:

BooleanType: 用于表示布尔值(true 或 false)。
字符串类型:

StringType: 用于表示字符串。
二进制类型:

BinaryType: 用于表示二进制数据。
日期和时间类型:

DateType: 用于表示日期。
TimestampType: 用于表示日期和时间。
数组类型:

ArrayType: 用于表示数组。
映射类型:

MapType: 用于表示键值对的映射。
结构类型:

StructType: 用于表示结构化的数据,可以包含多个字段。
空类型:

NullType: 用于表示空值。

这些数据类型都属于 org.apache.spark.sql.types 包,并在 Spark SQL 中提供用于构建 DataFrame 模式的工具。在创建 DataFrame 时,你可以使用这些数据类型来定义每列的数据类型。例如:

复制代码
import org.apache.spark.sql.types._

val schema = StructType(Seq(
  StructField("name", StringType, true),
  StructField("age", IntegerType, false),
  StructField("salary", DoubleType, true)
))

val df = spark.createDataFrame(spark.sparkContext.emptyRDD[Row], schema)
相关推荐
TM1Club4 小时前
AI驱动的预测:新的竞争优势
大数据·人工智能·经验分享·金融·数据分析·自动化
zhang133830890754 小时前
CG-09H 超声波风速风向传感器 加热型 ABS材质 重量轻 没有机械部件
大数据·运维·网络·人工智能·自动化
电商API_180079052475 小时前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫
龙山云仓5 小时前
No140:AI世间故事-对话康德——先验哲学与AI理性:范畴、道德律与自主性
大数据·人工智能·深度学习·机器学习·全文检索·lucene
躺柒7 小时前
读数字时代的网络风险管理:策略、计划与执行04风险指引体系
大数据·网络·信息安全·数字化·网络管理·网络风险管理
独自归家的兔8 小时前
从 “局部凑活“ 到 “全局最优“:AI 规划能力的技术突破与产业落地实践
大数据·人工智能
海域云-罗鹏8 小时前
国内公司与英国总部数据中心/ERP系统互连,SD-WAN专线实操指南
大数据·数据库·人工智能
策知道9 小时前
依托政府工作报告准备省考【经验贴】
大数据·数据库·人工智能·搜索引擎·政务
Henry-SAP9 小时前
SAP(ERP) 组织结构业务视角解析
大数据·人工智能·sap·erp·sap pp
冷崖10 小时前
消息队列-kafka(一)
分布式·kafka