Orcal数据库Schema理解、表分区理解

目录

  • 1 Schema
    • 1.1 Orcal数据库示例
    • 1.2 MySQL数据库示例
  • 2 Orcal表分区
    • 2.1 创建表分区
    • 2.2 查看表分区
    • 2.3 查看指定分区数据

此前未了解过Schema的概念,仅知道Orcal数据库比较侧重这个概念,搜遍全网都,都是啰哩吧嗦的搬抄定义,特此在梳理后写下本文,模拟直观的示例通俗易懂,3min拿下理解

1 Schema

1.1 Orcal数据库示例

假设我们有一个多租户的应用,服务多个学校的学生信息。每个学校都有自己的数据,而且我们希望在同一个数据库实例中存储这些信息。使用schema可以很好地实现这个目标。

在这里插入图片描述

通过这种方式,每个学校的数据都被组织在自己的schema下,相互隔离。不同学校的表可以使用相同的名称,而不会发生命名冲突。

1.2 MySQL数据库示例

在MySQL中,相同的多租户场景可以使用不同的数据库来实现,而不需要关心用户和schema的概念。

在这里插入图片描述

在MySQL中,每个数据库是一个独立的命名空间,可以存储相同表名的表而不会发生冲突。因此,MySQL中不同数据库的隔离性通过数据库本身来实现,而不需要显式的用户和schema的概念。

可以这么说,比如你连接mysql环境xxx.xxx.xx.xx:8080,创建的数据库如下

  • 阳光中学数据库
  • 实验中学数据库
  • 彩虹中学数据库
  • 西南科技大学数据库
  • 清华大学数据库
  • 华中科技大学数据库
  • 朝阳街道办数据库
  • 凤凰南路街道办数据库

每个数据库对应不同的需求
你想要获取阳光中学的数据,就在项目中连接阳光中学的数据库
你想要获取西南科技大学的数据,就在项目中连接西南科技大学的数据库
完全没问题,这是mysql的操作,那么orcal如何处理呢

中学数据库

  • 阳光中学 (A)
  • 实验中学 (B)
  • 彩虹中学 (C)

大学数据库

  • 西南科技大学 (D)
  • 清华大学 (E)
  • 华中科技大学 (F)

街道办数据库

  • 朝阳街道办 (G)
  • 凤凰南路街道 (H)

每个数据库对应不同的需求
项目中连接中心数据库
你想要获取阳光中学的数据,就用身份A登陆
你想要获取彩虹中学的数据,就用身份C登陆

2 Orcal表分区

2.1 创建表分区

首先,让我们创建一个简单的分区表,然后演示如何查看分区信息。我们将使用范围分区作为示例。

-- 创建一个范围分区表,分区名为p0,p1, p2, p3
CREATE TABLE sales (
    sale_id INT,
    sale_date DATE,
    amount DECIMAL(10, 2)
) PARTITION BY RANGE (YEAR(sale_date)) (
    PARTITION p0 VALUES LESS THAN (2000),
    PARTITION p1 VALUES LESS THAN (2010),
    PARTITION p2 VALUES LESS THAN (2020),
    PARTITION p3 VALUES LESS THAN MAXVALUE
);

-- 插入一些数据
INSERT INTO sales VALUES
(1, '1999-05-15', 100.50),
(2, '2005-08-20', 150.75),
(3, '2015-03-10', 200.30),
(4, '2022-02-01', 120.90);

这个表分区是什么意思呢?
sale_date字段对应的是时间,将时间分成四档,每个时间关联的那一条数据一起被划分

2.2 查看表分区

查询表分区定义

SELECT * FROM information_schema.partitions WHERE table_name = 'sales';

只需关注PARTITION_NAME 和 PARTITION_DESCRIPTION 字段即可,可以看到,p0分区是2000档,p1是2010档
在这里插入图片描述

2.3 查看指定分区数据

查看 p0 分区的数据


SELECT * FROM sales PARTITION (p0);

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/231918.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

(JSP)EL——优化登录界面,获取对象,获取数据

EL优化登录界面 <% page language"java" import"java.util.*" pageEncoding"UTF-8"%> <% String path request.getContextPath(); String basePath request.getScheme()"://"request.getServerName()":"reques…

电源小白入门学习3——电源系统常见元件选型MOS管、二极管、电感篇

电源小白入门学习3——电源系统常见元件选型MOS管、二极管、电感篇 MOS管二极管电感 书接上文&#xff0c;上一期我们讲了电阻、电容选型中需要注意的事项&#xff0c;下面我们接着来介绍MOS管和二极管。 MOS管 关于MOS管的基本原理和内部的一些结构&#xff0c;PN结、半导体的…

分布式架构原理与实践读书笔记

分布式架构原理与实践读书笔记 IT 软件架构的更迭&#xff1a;从单体架构&#xff0c;到集群架构&#xff0c;到现在的分布式和微服务架构。 分布式架构具有分布性、自治性、并行性、全局性等特点。 为了应对请求的高并发和业务的复杂性&#xff0c;需要对应用服务进行合理拆…

用Rust刷LeetCode之27 移除元素

27. 移除元素 难度: 简单 原描述: 新描述: func removeElement(nums []int, val int) int { for i : 0; i < len(nums); i { if nums[i] val { nums append(nums[:i], nums[i1:]...) i-- } } return len(nums)} Rust 版本 下面这种写法编译无法通过: pub fn remove_…

标准成本核算基础知识 - 了解成本构成结构 - Part3

原文地址:Basics of Standard Costing – Understanding the Cost Component Structure-Part 3 | SAP Blogs 本文档是我的第二份文档http://scn.sap.com/docs/DOC-49167的延续- SAP 标准成本估算基础知识 - 了解成本核算变式 - 该系列的第 2 部分和第 3 部分 本文档解释了成本…

智能优化算法应用:基于蚁狮算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于蚁狮算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于蚁狮算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.蚁狮算法4.实验参数设定5.算法结果6.参考文献7.MA…

【腾讯云 HAI域探秘】StableDiffusionWebUI 让我找到了宫崎骏动漫里的夏天

目录 前言一、HAI二、应用场景三、构建 Stable Diffusion 模型1、新建HAI应用2、StableDiffusionWebUI&#xff08;1&#xff09;功能介绍&#xff08;2&#xff09;页面转中文&#xff08;3&#xff09;AI绘图① 正向提示词语② 反向提示词③ “” 、“ AND”、“|” 用法④ 权…

知识付费商城7.0.3开心学习版,新增供货商功能

彩虹知识付费商城7.0.3小森升级版新增供货商开心学习版。仅供开发参考&#xff0c;切勿正式商用。 1.新增邮件提醒功能&#xff0c;支持给用户发订单、结算等邮件通知 2.支持给管理员发送提现、域名审核等邮件通知 3.支持设置手续费最低扣除金额 4.修复了其他一些已知问题 …

交换机与VLAN

交换机简介 交换机的作用 如今随着计算机速度不断提高&#xff0c;以及网络应用越来越多&#xff0c;局域网的负载变得越来越大了&#xff0c;交换机的使用也变得更有必要。交换机的作用主要有两个&#xff1a;一个是维护CAM&#xff08;Context Address Memory&#xff09;表…

低多边形建筑3D模型纹理贴图

在线工具推荐&#xff1a; 3D数字孪生场景编辑器 - GLTF/GLB材质纹理编辑器 - 3D模型在线转换 - Three.js AI自动纹理开发包 - YOLO 虚幻合成数据生成器 - 三维模型预览图生成器 - 3D模型语义搜索引擎 当谈到游戏角色的3D模型风格时&#xff0c;有几种不同的风格&#xf…

c++新经典模板与泛型编程:引用类型的移除与增加

引用类型的移除 c11标准库中提供了一个std::remove_reference类模板&#xff0c;如果传递进来的模板参数是一个引用类型&#xff0c;则会把这个引用类型中的引用部分删除&#xff0c;先看一下用法&#xff1a; #include <iostream>template<class T1,class T2> vo…

Mysql研学-认识与安装

一 数据库 1 Java的数据存储技术 ① 变量:一个数据存储空间的表示 ② 数组:存储一组相同数据类型的"容器" ③ 集合:存储一组任意引用数据类型的"容器" ④ 配置文件: .properties:基于Properties集合存储(Map集合的具体实例) .xml文件:基于标签存储数据…

【精选】设计模式——工厂设计模式

工厂设计模式是一种创建型设计模式&#xff0c;其主要目的是通过将对象的创建过程封装在一个工厂类中来实现对象的创建。这样可以降低客户端与具体产品类之间的耦合度&#xff0c;也便于代码的扩展和维护。 工厂设计模式&#xff1a; 以下是Java中两个常见的工厂设计模式示例…

LCR 090. 打家劫舍 II(leetcode)动态规划

文章目录 前言一、题目分析二、算法原理1.状态表示2.状态转移方程3.初始化4.填表顺序5.返回值是什么 三、代码实现总结 前言 在本文章中&#xff0c;我们将要详细介绍一下LeetcodeLCR 090. 打家劫舍 II。采用动态规划解决&#xff0c;这是一道经典的多状态dp问题 一、题目分析…

Qt开发 之 Qt5各版本情况分析

文章目录 1、简介2、Qt5 版本归纳3、下载地址3.1、典型版本3.1.1、Qt5.0.03.1.2、Qt5.9.93.1.3、Qt5.12.12 3.2、当前Qt5最新版本 1、简介 Qt6 出生刚刚好一年的时间&#xff0c;已经出到6.6版本&#xff0c;带来了许多的新特性和改进。今天刚刚好抽空总结下陪伴 我工作这么长…

【vim】常用操作

用的时候看看&#xff0c;记太多也没用&#xff0c;下面都是最常用的&#xff0c;更多去查文档vim指令集。 以下均为正常模式下面操作&#xff0c;正在编辑的&#xff0c;先etc一下. 1/拷贝当前行 yy&#xff0c;5yy为拷贝包含当前行往下五行 2/p将拷贝的东西粘贴到当前行下…

学习Linux(2)-学习Linux命令

Linux目录结构 Linux目录结构-菜鸟教程 /bin&#xff1a;bin 是 Binaries (二进制文件) 的缩写, 这个目录存放着最经常使用的命令。 /boot&#xff1a;这里存放的是启动 Linux 时使用的一些核心文件&#xff0c;包括一些连接文件以及镜像文件。 /dev &#xff1a;dev 是 De…

【Vue】登录注册界面制作

1. 创建vue项目 https://blog.csdn.net/m0_67930426/article/details/134816155?spm1001.2014.3001.5502 2. 整合element-ui https://blog.csdn.net/m0_67930426/article/details/134827986?spm1001.2014.3001.5502 在view目录下创建文件 本篇内容使用到了 v-model cl…

飞天使-linux操作的一些技巧与知识点3

http工作原理 http1.0 协议 使用的是短连接&#xff0c;建立一次tcp连接&#xff0c;发起一次http的请求&#xff0c;结束&#xff0c;tcp断开 http1.1 协议使用的是长连接&#xff0c;建立一次tcp的连接&#xff0c;发起多次http的请求&#xff0c;结束&#xff0c;tcp断开ngi…