物化视图mysql,ClickHouse的物化视图及MySQL表引擎

-- . 在MySQL中创建表定义和加入数据:

mysql> selectversion();+-----------+

| version() |

+-----------+

| 8.0. |

+-----------+

row in set (0.01sec)

mysql>show create table t_org\G*************************** . row ***************************Table: t_org

Create Table: CREATE TABLE `t_org` (

`ID`intNOT NULL AUTO_INCREMENT,

`org_code` varchar() DEFAULT NULL,

`org_name` varchar() DEFAULT NULL,

`lastmodifytime` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,

PRIMARY KEY (`ID`)

) ENGINE=InnoDB AUTO_INCREMENT= DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci row in set (0.00sec)

插入数据:

insert into t_org(org_code,org_name)values('A01','研发部'),('A02','产品部'),('A03','测试部'),('A04','数据部'),('A05','运维部');.在clickhouse中对MySQL表引擎建立映射:

Clickhouse> create table t_org(ID UInt32,org_code String,org_name String,LASTMODIFYTIME Datetime)ENGINE=MySQL('192.168.8.110:3306','datasets','t_org','root','oracle');

CREATE TABLE t_org

(

`ID` UInt32,

`org_code` String,

`org_name` String,

`LASTMODIFYTIME` Datetime

)

ENGINE= MySQL('192.168.8.110:3306', 'datasets', 't_org', 'root', 'oracle')

Ok. rows in set. Elapsed: 0.002sec.

注意:.MySQL 中的Decimal(p,s) 类型在Clickhouse中的定义的差异.clickhouse的数据库引擎 ENGINE =MySQL 这里的MySQL必须要是MySQL

否则报错信息:

Received exceptionfrom server (version 20.4.):

Code:. DB::Exception: Received from localhost:. DB::Exception: Unknown table engine Mysql. Maybe you meant: ['MySQL'].

查看表的定义:

Clickhouse>desc t_org;

DESCRIBE TABLE t_org

┌─name───────────┬─type─────┬─default_type─┬─default_expression─┬─comment─┬─codec_expression─┬─ttl_expression─┐

│ ID │ UInt32 │ │ │ │ │ │

│ org_code │ String │ │ │ │ │ │

│ org_name │ String │ │ │ │ │ │

│ LASTMODIFYTIME │ DateTime │ │ │ │ │ │

└────────────────┴──────────┴──────────────┴────────────────────┴─────────┴──────────────────┴────────────────┘ rows in set. Elapsed: 0.002sec.--查询clickhouse的定义:

Clickhouse> select * fromt_org;

SELECT*FROM t_org

┌─ID─┬─org_code─┬─org_name─┬──────LASTMODIFYTIME─┐

│ │ A01 │ 研发部 │ -- ::│

│ │ A02 │ 产品部 │ -- ::│

│ │ A03 │ 测试部 │ -- ::│

│ │ A04 │ 数据部 │ -- ::│

│ │ A05 │ 运维部 │ -- ::│

└────┴──────────┴──────────┴─────────────────────┘ rows in set. Elapsed: 0.007sec.

在MySQL 中插入新的数据:

insert into t_org(org_code,org_name)values('A06','销售部'),('A07','人力部');

在clickhouse中查询:

Clickhouse> select * fromt_org;

SELECT*FROM t_org

┌─ID─┬─org_code─┬─org_name─┬──────LASTMODIFYTIME─┐

│ │ A01 │ 研发部 │ -- ::│

│ │ A02 │ 产品部 │ -- ::│

│ │ A03 │ 测试部 │ -- ::│

│ │ A04 │ 数据部 │ -- ::│

│ │ A05 │ 运维部 │ -- ::│

│ │ A06 │ 销售部 │ -- ::│

│ │ A07 │ 人力部 │ -- ::│

└────┴──────────┴──────────┴─────────────────────┘ rows in set. Elapsed: 0.005sec.

数据已经和MySQL中的数据一样。

在MySQL中更新数据:

mysql> update t_org set org_name='财务部' where org_code='A07';

Query OK, row affected (0.00sec)

Rows matched: Changed: Warnings: mysql> select * fromt_org;+----+----------+-----------+---------------------+

| ID | org_code | org_name | lastmodifytime |

+----+----------+-----------+---------------------+

| | A01 | 研发部 | -- :: |

| | A02 | 产品部 | -- :: |

| | A03 | 测试部 | -- :: |

| | A04 | 数据部 | -- :: |

| | A05 | 运维部 | -- :: |

| | A06 | 销售部 | -- :: |

| | A07 | 财务部 | -- :: |

+----+----------+-----------+---------------------+

rows in set (0.00sec)

在Clickhouse中查询:

Clickhouse> select * fromt_org;

SELECT*FROM t_org

┌─ID─┬─org_code─┬─org_name─┬──────LASTMODIFYTIME─┐

│ │ A01 │ 研发部 │ -- ::│

│ │ A02 │ 产品部 │ -- ::│

│ │ A03 │ 测试部 │ -- ::│

│ │ A04 │ 数据部 │ -- ::│

│ │ A05 │ 运维部 │ -- ::│

│ │ A06 │ 销售部 │ -- ::│

│ │ A07 │ 财务部 │ -- ::│

└────┴──────────┴──────────┴─────────────────────┘ rows in set. Elapsed: 0.003sec.

通过clickhouse查询远程的数据 可以看到数据一样发生了变化。---delete 操作:

mysql> delete from t_org where org_code='A07';

Query OK, row affected (0.00sec)

mysql> select * from t_org where org_code='A07';

Emptyset (0.00sec)

Clickhouse> select * fromt_org;

SELECT*FROM t_org

┌─ID─┬─org_code─┬─org_name─┬──────LASTMODIFYTIME─┐

│ │ A01 │ 研发部 │ -- ::│

│ │ A02 │ 产品部 │ -- ::│

│ │ A03 │ 测试部 │ -- ::│

│ │ A04 │ 数据部 │ -- ::│

│ │ A05 │ 运维部 │ -- ::│

│ │ A06 │ 销售部 │ -- ::│

└────┴──────────┴──────────┴─────────────────────┘ rows in set. Elapsed: 0.004sec.---使用雾化视图:

Clickhouse> create materialized view mv_t_org engine=MergeTree() order by ID as select * fromt_org;

CREATE MATERIALIZED VIEW mv_t_org

ENGINE=MergeTree()

ORDER BY ID AS

SELECT*FROM t_org

Ok. rows in set. Elapsed: 0.004 sec.

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java面向对象和面向过程有什么区别?网友:傻傻分不清楚……

面向对象,Obeject Oriented,是一种编程术语。面向对象是当今软件开发方法的主流方法之一,他是把数据以及对数据的操作放在一起,作为一个相互依存的整体,就是我们所说的对象。对同类对象抽象出其共性,就是类…

oracle oic配置,Oracle数据库 client配置

以下是11g client配置1. 从OTN下载几个压缩包下载地址为: http://www.oracle.com/technology/software/tech/oci/instantclient/index.html然后根据你的平台,选择不同的下载,我是安装在rhel5下,所以选择了linux x86 并下载了下面2…

Java 反射机制和动态代理是基于什么原理,了解过吗?

工作多年以及在面试中,我经常能体会到,有些面试者确实是认真努力工作,但坦白说表现出的能力水平却不足以通过面试,通常是两方面原因: 1、“知其然不知其所以然”。 做了多年技术,开发了很多业务应用&#x…

oracle执行sql痕迹,Oracle 查询刚执行的SQL

Oracle 查询刚刚执行的SQLselect "SQL_TEXT","SQL_FULLTEXT","SQL_ID","SHARABLE_MEM","PERSISTENT_MEM","RUNTIME_MEM","SORTS","LOADED_VERSIONS","OPEN_VERSIONS","USERS_…

成长为一名Java架构师需要掌握的技术有哪些呢?

Java架构师需要掌握的技术: 1、熟练使用各种框架,并知道它们实现的原理。 2、jvm虚拟机原理、调优,懂得jvm能让你写出性能更好的代码; 3、池技术,什么对象池,连接池,线程池……Java反射技术&…

php 分布式数据库查询,分布式数据库

# 分布式数据库ThinkPHP内置了分布式数据库的支持,包括主从式数据库的读写分离,但是分布式数据库必须是相同的数据库类型。配置database.deploy 为1 可以采用分布式数据库支持。如果采用分布式数据库,定义数据库配置信息的方式如下&#xff1…

Java程序员遇到瓶颈后我们可以试着朝四个方向拓展?你们觉得呢?

现如今随着IT行业的火热,人们对于编程技术也是越来越关注重视,在从业后我们做Java开发难免会遇到一些瓶颈。在我看来解决这个问题一般有以下4种方向: 基于产品本身 要记住公司招人是解决问题的,基于现有问题出发,大家…

oracle 布尔盲注,Oracle基于延时的盲注总结

0x00 前言oracle注入中可以通过页面响应的状态,这里指的是响应时间,通过这种方式判断SQL是否被执行的方式,便是时间盲注;oracle的时间盲注通常使用DBMS_PIPE.RECEIVE_MESSAGE(),而另外一种便是decode()与高耗时SQL操作…

Java架构师除了必备的技术之外,这些技能也需必备?你们觉得呢?

成为Java架构师首先你必须是一名Java高级开发工程师,熟练使用各种框架,并且能知道他们其中的原理。jvm虚拟机原理、调优,懂得jvm能让你写出性能更好的代码;池技术,什么对象池,连接池,线程池等等 Java构架师…

bat oracle导出数据库,bat命令oracle自动备份

echo offecho echo windows环境下Oracle数据库的自动备份脚本echo 说明:启动备份时,需要配置以下变量echo 1、BACKUP_DIR 指定要备份到哪个目录echo 2、ORACLE_USERNAME 指定备份所用的Oracle用户名echo 3、ORACLE_PASSWORD 指定备份所用的Oracle密码ech…

Java编程学习并不难,有坚持的动力与良好的心态尤为重要

时间过得很快,回想刚学习Java编程开发的懵懂无知,到现在可以做出简单的项目,可以明显的感觉到自己确实进步了。Java编程其实并不难学,难的是你能够一如既往的保持好的学习态度,并愿意努力的去背、去记、去做项目练习。…

php常用函数、算法,PHP常用函数和常量

PHP常用系统常量__FILE__文件的完整路径和文件名。如果用在被包含文件中,则返回被包含的文件名。自 PHP 4.0.2 起,总是包含一个绝对路径(如果是符号连接,则是解析后的绝对路径),而在此之前的版本有时会包含一个相对路径。__DIR__文…

Java编程开发中高效编码的7个技巧?你应该知道……

1. 使用 JDK 8 或更高版本 从 JDK 8 以及 更高版本开始,引进许多新功能将允许你编写更短、更具表现力的代码,包括 lambda 表达式、functional 接口、stream API等。你实际上不需要记住他们,因为 IDEA 将帮助你使用这些功能,这也是…

下载jdk一定要登录oracle么,如何下载oracle jdk|oracle jdk下载慢,要登录等等问题

/java/jdk/8u231-b11/5b13a193868b4bf28bcb45c792fce896/jdk-8u231-linux-x64.tar.gz注意替换--------------------------------------------附上一批网址,这些应该也够了http://ns1.iranns.ir 这个比较新https://mirrors.huaweicloud.com/java/http://enos.itcoll…

oracle 11g segment,11g视图dba_segments中增加了一个有用的segment_subtype字段!

以前我们要查一个segment所在的表空间是assm还是mssm,需要查看这个segment所在的表空间的segment_space_management 字段属性,在11g中不需要了,只需要查看dba_segments的segment_subtype就可以了,看似一个小小的改进,却…

谈谈Java与大数据之间的关系你们都了解了清楚了吗?

Java是计算机编程语言界的王者,大数据是当下IT领域中最新潮的技术,Java和大数据都是当下十分受企业欢迎的IT技术,也是企业核心竞争力的重要组成部分,都说学大数据要先学Java,那么Java和大数据有什么关系呢?…

linux用户组chownd,Linux系统centos6下用户与用户组权限命令用法 chmod与chown

查看当前目录下文件的权限:命令:ll 或:ls -l-rw-r--r--. 1 root root 6 Nov 9 16:42 abc.htmldrw-r--r--. 1 root root 6 Nov 9 16:42 pages其中“-rw-r–r–”表示权限,一共有十个字符。第一个字符,如果是“-”则表示…

自学Java必看的知识点,猿们怎么看?

1.你需要精通面向对象分析与设计(OOA/OOD)、涉及模式(GOF,J2EEDP)以及综合模式。你应该了解UML,尤其是class、object、interaction以及statediagrams。 2. 你需要学习Java语言的基础知识以及它的核心类库(collections、serialization、streams、network…

linux 源码包编译,源码包编译安装

程序包编译安装:Application-VERSION-release.src.rpm–> 安装后,使用rpmbuild命令制作成二进制格式的rpm包,而后再安装源代码 –> 预处理 –> 编译 –> 汇编 –> 链接 –> 执行源代码组织格式:多文件&#xff…

谈一谈Java编程开发中虚拟机的内存区域划分?猿们怎么看?

java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域,有的区域随虚拟机进程的启动而存在,有的区域则依赖线程而存在。包括以下几个运行时数据区域: 程序计数器(线程私有): 可以…