Starrocks表的数据库字段类型及与MySQL 的差异

server/2024/10/19 18:19:30/

在这里插入图片描述
最近有用到Starrocks,实际使用中基本可以当作mysql来使用,但是数据库字段还是有所不同的。

  1. 与MySQL相同或相似的基础类型

    • 数值类型
      • TINYINT、SMALLINT、INT/INTEGER、BIGINT:在Starrocks和MySQL中的定义和用途基本相似。都是用于存储整数,范围也和MySQL中的对应类型相同,例如TINYINT在两者中都是占用1个字节的有符号整数,范围是 - 128到127。
      • FLOAT、DOUBLE、DECIMAL:这几种用于存储浮点数和定点数的类型在Starrocks和MySQL中的概念一致。如DECIMAL类型在两者中都是用于高精度的数值存储,格式DECIMAL(M, N)的含义相同,M表示数字总位数,N表示小数位数。
    • 字符串类型
      • CHAR、VARCHAR、TEXT:这些字符串类型在Starrocks和MySQL中有相似的功能。CHAR是定长字符串,VARCHAR是变长字符串,TEXT用于存储长文本内容。例如,在存储用户名称时,都可以使用VARCHAR来根据实际名称长度灵活存储。
    • 日期和时间类型
      • DATE、DATETIME、TIMESTAMP:它们在两种数据库中的格式和基本用途类似。DATE用于存储日期,DATETIME用于存储日期和时间,TIMESTAMP用于存储时间戳相关信息,并且在格式上(如DATE为’YYYY - MM - DD’)是相同的。
    • 布尔类型
      • BOOLEAN:在Starrocks和MySQL中都是用于表示真假值,用法一致,例如在表示用户是否激活账号等场景下使用。
  2. Starrocks特有的或有差异的类型

    • 复杂类型
      • ARRAY
        • MySQL没有像Starrocks这样原生支持数组类型作为表字段类型。在Starrocks中,ARRAY类型可以用于存储一组相同类型的数据,例如可以存储一个用户的多个标签(ARRAY[‘tag1’, ‘tag2’, ‘tag3’]),在处理具有多个关联属性的数据时提供了更方便的存储方式。
      • MAP
        • MySQL没有类似的原生字段类型。Starrocks的MAP类型可以存储键值对,例如存储一个产品的属性和对应的值(如{ “color”: “red”, “size”: “L” }),这种类型适合存储具有多个属性的复杂对象的数据。
    • HyperLogLog类型(用于基数估算)
      • 这是Starrocks特有的类型。它用于在大数据场景下高效地估算数据集中不同元素的数量(基数)。例如,在统计网站的独立访客数量(不考虑访客的访问次数,只关注不同的访客)时,使用HyperLogLog类型可以在占用较少内存的情况下快速估算出访客的大致数量。这种类型在MySQL中没有直接对应的原生字段类型用于类似功能。

http://www.ppmy.cn/server/131479.html

相关文章

请解释一下Java中的泛型擦除。你对Java中的XML和JSON了解多少?

请解释一下Java中的泛型擦除。 Java中的泛型擦除(Type Erasure)是指Java编译器在编译泛型代码时,会移除泛型类型参数的相关信息,使得生成的字节码中不包含泛型类型信息。这个过程使得Java的泛型在运行时(Runtime&…

树莓派应用--AI项目实战篇来啦-15.SSD Mobilenet V3目标检测

1. Mobilenet 介绍 Mobilenet 是一种专为移动和嵌入式视觉应用而设计的卷积神经网络。它们不使用标准的卷积层,而是基于使用深度可分离卷积的简化架构,使用这种架构,我们可以为移动和嵌入式设备(例如:树莓派&#xff0…

WPF 的 TreeView.SelectedItem和TreeViewItem.DataContext是一样的对象

TreeView.SelectedItem 类型:object作用:TreeView.SelectedItem 表示在 TreeView 控件中当前被选中的项(TreeViewItem 或其数据对象)。这个属性通常用于绑定或获取当前选中的项。用法:当你点击 TreeView 中的某个项时…

QT QML 练习2

这段代码使用 QtQuick 实现了一个简单的 GUI 界面,主要功能是展示一个背景图像、一个风车杆和一个可以旋转的风车。点击风车时,风车可以开始或者停止旋转。以下是对代码的详细介绍。 代码结构及实现细节 导入 QtQuick import QtQuick该语句引入了 QtQui…

2024 第一次周赛

A: 题目大意 骑士每连续 i 天每天会得到 i 个金币,(i 1, 2, 3 , …),那么展开看每一天可以得到的金币数:1 2 2 3 3 3 4 4 4 5 5 5 5 5 … 可以发现就是1个1 ,2个2, 3个3…,那么我…

深度学习之残差网络ResNet

文章目录 1. 残差网络定义2. 数学基础函数类3. 残差块4.ResNet模型5.训练模型6.小结 1. 残差网络定义 随着我们设计的网络越来越深,深刻理解“新添加的层如何提升神经网络的性能”变得至关重要。更重要的是设计网络的能力。在这种网络中,添加层会使得网…

Mybatis高级查询-一对多查询

表介绍和表关系说明 新建以下4张表 tb_user:用户表 tb_order:订单表 tb_item:商品表 tb_orderdetail:订单详情表 【表关系】 1.tb_user和 tb_order表关系tb_user 《》 tb_order:一对多, 一个人可以下多…

自动化测试-selenium

什么是自动化测试? 在预设条件下(自动化脚本)运行系统,预设的条件包括正常和异常的情况,不需要手工的干涉,机器就可以执行。 自动化测试的优势? 降低大型系统由于变更引起的大量的回归测试的人力…