HBase Cassandra的部署和操作
目录
一.数据库的部署与配置
二.使用命令访问数据库
三.数据库的设计
四.编程实现数据库的访问
一.数据库的部署与配置
1.在单个节点上对进行数据库的单机部署
(1)下载apache-cassandra-4.1.7-bin.tar.gz,上传到hadoop1 的/export/software目录
(2)使用解压缩命令:tar -xzf /export/software/apache-cassandra-4.1.7-bin.tar.gz -C /export/servers/ 进行解压缩到/export/servers目录
(3)使用cd /export/servers命令进入/export/servers目录
(4)将Cassandra目录进行重命名:mv apache-cassandra-4.1.7 apache-cassandra-4.1.7-standalone
(5)启动Cassandra:bin/cassandra -R
(6)查看Cassandra启动信息:tail -f logs/system.log
(7)检查状态:bin/nodetool status
(8)连接数据库:bin/cqlsh
(9)关闭Cassandra:bin/nodetool stopdaemon
2.在多个节点上实现数据库的分布式部署
(1)在Hadoop1、Hadoop2和Hadoop3上分别执行systemctl stop firewalld和systemctldisable firewalld命令关闭防火墙;
(2)在Hadoop1、Hadoop2、Hadoop3上分别执行ssh-keygen,ssh-copy-id hadoop1,ssh-copy-id hadoop2,ssh-copy-id hadoop3,使各个节点可以免密登录
注:在Hadoop2和Hadoop3上的执行结果与Hadoop1几乎相同,故不再展示。
(3)进行免密登录测试,在Hadoop1、Hadoop2和Hadoop3上分别执行ssh hadoop1,ssh hadoop2,ssh hadoop3,可以免密登录即可
注:在Hadoop2和Hadoop3上的执行结果与Hadoop1几乎相同,故不再展示。
(4)在Hadoop1、Hadoop2和Hadoop3上分别上传压缩安装包
(5)在Hadoop1、Hadoop2和Hadoop3上分别解压缩apache-cassandra-4.1.7-bin.tar.gz:tar -xzf /export/software/apache-cassandra-4.1.7-bin.tar.gz -C /export/servers/
(6)分别修改Hadoop1、Hadoop2和Hadoop3的cassandra.yaml文件中的seeds、listen_address和rpc_address,具体修改如下:
Hadoop1:seeds=192.168.121.160,listen_address=192.168.121.160,rpc_address=192.168.121.160;
Hadoop1:seeds=192.168.121.160,listen_address=192.168.121.161,rpc_address=192.168.121.161;
Hadoop1:seeds=192.168.121.160,listen_address=192.168.121.162,rpc_address=192.168.121.162
注:因修改过程类似,此处只展示Hadoop1节点上的修改结果。
(7)在Hadoop1、Hadoop2和Hadoop3上使用命令分别启动Cassandra:
bin/cassandra -R
(8)查看运行状态:bin/nodetool status
(9)连接任一服务器均可:bin/cqlsh hadoop1,bin/cqlsh hadoop2,bin/cqlsh hadoop3
二.使用命令访问数据库
练习Cassandra的相关命令。
1.键空间:创建、删除和查看键空间
(1)创建并查看键空间
CREATE KEYSPACE IF NOT EXISTS library_system
WITH REPLICATION = {
'class' : 'SimpleStrategy',
'replication_factor' : 1
};
DESCRIBE KEYSPACES;
(2)删除并再次查看键空间
DROP KEYSPACE IF EXISTS library_system;
DESCRIBE KEYSPACES;
2.表:创建表、设置复合型主键、修改表结构(要求:复合主键要包括分区键和分簇键,数据类型要包含两种以上的集合类型和一种以上的自定义类型)
以图书管理系统为例进行如下操作:
(1)创建表(包含复合型主键)
在图书管理系统中,我们设计一个图书借阅记录表,复合主键由 book_id 和 borrower_id 组成,分区键使用 book_id,集群键使用 borrower_id。还使用了集合类型(SET)存储借阅的日期,以及自定义类型(user_info)来存储借阅人的信息。
语句如下:
CREATE TYPE IF NOT EXISTS library_system.user_info (
name TEXT,
email TEXT,
phone_number TEXT
);
CREATE TABLE IF NOT EXISTS library_system.book_borrowing (
book_id UUID, -- 分区键
borrower_id UUID, -- 集群键
borrow_date DATE, -- 借阅日期
return_date DATE, -- 归还日期
status TEXT, -- 状态(如 已借出、已归还)
tags SET<TEXT>, -- 标签(如 热门、推荐等)
borrower_info FROZEN<user_info>, -- 自定义类型,借阅人信息
PRIMARY KEY (book_id, borrower_id) -- 复合主键
);
其中,book_id是分区键,borrower_id 是集群键,tags 是集合类型,用来存储书籍标签,borrower_info 是自定义类型 user_info,用于存储借阅人的信息。
(2)修改表结构
添加一个新列来记录图书的借阅次数。
语句如下:
ALTER TABLE library_system.book_borrowing ADD borrow_count INT;
3.数据查询
(1)查询所有数据
SELECT * FROM library_system.book_borrowing;
(2)根据分区键查询
SELECT * FROM library_system.book_borrowing WHERE book_id = 3796171a-9a3d-45e6-8886-42601fed5c04;
(3)根据分区键和集群键查询
SELECT * FROM library_system.book_borrowing WHERE book_id = b8cdcddb-4b1e-4937-83cd-dbfbf5288671 AND borrower_id = b36f25ca-082c-4ded-afc9-6675eda47cd4;
(4)查询特定列
SELECT book_id, borrow_date, return_date FROM library_system.book_borrowing WHERE book_id = b8cdcddb-4b1e-4937-83cd-dbfbf5288671 AND borrower_id = b36f25ca-082c-4ded-afc9-6675eda47cd4;
(5)查询集合类型数据
SELECT tags FROM library_system.book_borrowing WHERE book_id = b8cdcddb-4b1e-4937-83cd-dbfbf5288671 AND borrower_id = b36f25ca-082c-4ded-afc9-6675eda47cd4;
(6)查询自定义类型数据
SELECT borrower_info FROM library_system.book_borrowing WHERE book_id = b8cdcddb-4b1e-4937-83cd-dbfbf5288671 AND borrower_id = b36f25ca-082c-4ded-afc9-6675eda47cd4;
4.数据更新:数据插入、数据更新、数据删除
(1)数据插入
INSERT INTO library_system.book_borrowing (book_id, borrower_id, borrow_date, return_date, status, tags, borrower_info)
VALUES (uuid(), uuid(), '2024-01-01', '2024-01-15', 'Borrowed', {'Popular', 'New Release'},
{name: 'John Doe', email: 'johndoe@example.com', phone_number: '1234567890'});
(2)数据更新
UPDATE library_system.book_borrowing
SET return_date = '2024-01-20', status = 'Returned'
WHERE book_id = b8cdcddb-4b1e-4937-83cd-dbfbf5288671 AND borrower_id = b36f25ca-082c-4ded-afc9-6675eda47cd4;
(3)数据删除
①删除单条数据
DELETE FROM library_system.book_borrowing
WHERE book_id = b8cdcddb-4b1e-4937-83cd-dbfbf5288671 AND borrower_id = b36f25ca-082c-4ded-afc9-6675eda47cd4;
②删除整张表
TRUNCATE library_system.book_borrowing;
三.数据库的设计
图书管理系统包含三个主要实体:图书、读者和借阅记录。它们之间通过一个关系来进行联系,借阅记录表示图书与读者之间的借阅关系,本系统共设计三张表,分别是图书表(存储图书的相关信息)、借阅记录表(存储借阅的记录)和读者表(存储读者的基本信息)。
1.数据库设计
(1)图书表
表名:Books
列族(Column Families):
info:存储图书的基本信息
author:存储作者的详细信息
publisher:存储出版商的信息
行键设计:
行键:book_id(唯一标识每本图书)
列名与存储内容:
在info列族下:
title:书名
category:类别(如科幻、文学等)
published_date:出版日期
在author列族下:
name:作者名称
birth_date:作者出生日期
在publisher列族下:
publisher_name:出版商名称
publisher_address:出版商地址
(2)读者表
表名:Readers
列族(Column Families):
info:存储读者的基本信息
contact:存储读者的联系信息(例如地址、电话)
行键设计:
行键:reader_id(唯一标识每个读者)
列名与存储内容:
在info列族下:
reader_name:读者姓名
dob:出生日期
在contact列族下:
email:电子邮件地址
phone_number:电话号
address:家庭住址
(3)借阅记录表
表名:BorrowRecords
列族(Column Families):
info:存储借阅信息
reader:存储读者信息
行键设计:
行键:borrow_id(唯一标识每次借阅记录)
列名与存储内容:
在info列族下:
book_id:借阅的图书ID
borrow_date:借阅日期
return_date:归还日期
在reader列族下:
reader_name:读者姓名
reader_id:读者ID
(4)实体和关系的增删改查
①新增操作
新增图书:向Books表中插入新的行,包含图书ID(行键)及其对应的列族和列名。
新增借阅记录:向BorrowRecords表中插入新的行,包含借阅记录ID(行键)、借阅图书ID、借阅日期、归还日期、读者信息等。
新增读者:向Readers表中插入新的行,包含读者ID(行键)、姓名、出生日期、联系信息等。
②删除操作
删除图书:通过图书ID删除Books表中的记录。
删除借阅记录:通过借阅记录ID删除BorrowRecords表中的记录。
删除读者:通过读者ID删除Readers表中的记录。
③更新操作
更新图书信息:可以根据图书ID(行键)来更新Books表中的某些列,比如更新书名、作者或出版日期等。
更新借阅记录:可以根据借阅记录ID(行键)来更新借阅日期或归还日期等。
更新读者信息:可以根据读者ID(行键)来更新Readers表中的读者姓名、地址、电话等。
④查询操作
查询某本图书的详细信息:通过book_id查询Books表中的详细信息。
查询某本图书的借阅记录:通过book_id在BorrowRecords表中查找所有借阅记录。
查询某位读者的借阅记录:通过reader_id在BorrowRecords表中查找该读者的所有借阅记录。
查询某位读者的详细信息:通过reader_id查询Readers表中的详细信息。
2.表设计与填充数据
(1)图书表
| 行键(book_id) | 列族 | 列名 | 列值 |
| B001 | info | title | 《活着》 |
| category | 文学 | ||
| published_date | 1993-06-01 | ||
| author | name | 余华 | |
| birth_date | 1960-04-03 | ||
| publisher | publisher_name | 作家出版社 | |
| publisher_address | 北京市朝阳区 | ||
| B002 | info | title | 《百年孤独》 |
| category | 小说 | ||
| published_date | 1967-06-05 | ||
| author | name | 加西亚·马尔克斯 | |
| birth_date | 1927-03-06 | ||
| publisher | publisher_name | 南海出版公司 | |
| publisher_address | 上海市徐汇区 |
(2)读者表
| 行键(reader_id) | 列族 | 列名 | 列值 |
| R001 | info | reader_name | 张三 |
| dob | 1990-05-15 | ||
| contract | | zhsan@email.com | |
| phone_number | 123-4567-8901 | ||
| address | 北京市海淀区 | ||
| R002 | info | reader_name | 李四 |
| dob | 2005-02-28 | ||
| contract | | lisi@email.com | |
| phone_number | 987-6543-2100 | ||
| address | 上海市浦东新区 |
(3)借阅记录表
| 行键(borrow_id) | 列族 | 列名 | 列值 |
| BR001 | info | Book_id | B001 |
| Borrow_date | 2024-11-01 | ||
| Return_date | 2024-11-15 | ||
| reader | Reader_name | 张三 | |
| Reader_id | R001 | ||
| BR001 | info | Book_id | B002 |
| Borrow_date | 2024-11-02 | ||
| Return_date | 2024-11-20 | ||
| reader | Reader_name | 李四 | |
| Reader_id | R002 |
四.编程实现数据库的访问
使用Python访问实现设计的图书管理系统的列式数据库,步骤如下:
(1)数据库连接:连接到Cassandra集群,并创建数据库library和数据表Books、Readers和BorrowRecords,具体代码如下:
from cassandra.cluster import Cluster
# 连接到 Cassandra 集群
cluster = Cluster(['192.168.121.160']) 虚拟机的 IP 地址
session = cluster.connect()
# 创建 Keyspace:library
session.execute("""
CREATE KEYSPACE IF NOT EXISTS library WITH replication = {'class': 'SimpleStrategy', 'replication_factor': 1}
""")
# 使用创建的 Keyspace
session.execute("USE library")
# 创建表结构
# 创建 Books 表
session.execute("""
CREATE TABLE IF NOT EXISTS Books (
book_id TEXT PRIMARY KEY,
title TEXT,
category TEXT,
published_date TEXT,
author_name TEXT,
author_birth_date TEXT,
publisher_name TEXT,
publisher_address TEXT
)
""")
# 创建 Readers 表
session.execute("""
CREATE TABLE IF NOT EXISTS Readers (
reader_id TEXT PRIMARY KEY,
reader_name TEXT,
dob TEXT,
email TEXT,
phone_number TEXT,
address TEXT
)
""")
# 创建 BorrowRecords 表
session.execute("""
CREATE TABLE IF NOT EXISTS BorrowRecords (
borrow_id TEXT PRIMARY KEY,
book_id TEXT,
borrow_date TEXT,
return_date TEXT,
reader_name TEXT,
reader_id TEXT
)
""")
print("Keyspace and tables created.")
结果如下图所示:
(2)数据增加
分别给三张表插入数据,具体代码如下:
①插入图书记录
session.execute("""
INSERT INTO Books (book_id, title, category, published_date, author_name, author_birth_date, publisher_name, publisher_address)
VALUES (%s, %s, %s, %s, %s, %s, %s, %s)
""", ('B001', '《活着》', '文学', '1993-06-01', '余华', '1960-04-03', '作家出版社', '北京市朝阳区'))
结果如下图所示:
②插入读者信息
session.execute("""
INSERT INTO Readers (reader_id, reader_name, dob, email, phone_number, address)
VALUES (%s, %s, %s, %s, %s, %s)
""", ('R001', '张三', '1990-05-15', 'zhangsan@email.com', '123-4567-8901', '北京市海淀区'))
结果如下图所示:
③插入借阅记录
session.execute("""
INSERT INTO BorrowRecords (borrow_id, book_id, borrow_date, return_date, reader_name, reader_id)
VALUES (%s, %s, %s, %s, %s, %s)
""", ('BR001', 'B001', '2024-11-01', '2024-11-15', '张三', 'R001'))
结果如下图所示:
(3)数据更新
更新读者的联系方式,具体代码如下:
session.execute("""
UPDATE Readers SET email = %s WHERE reader_id = %s
""", ('newemail@email.com', 'R001'))
结果如下图所示:
(4)数据查询
查询book_id为B001图书的详细信息,具体代码如下:
# 查询某本图书的详细信息
rows = session.execute("""
SELECT * FROM Books WHERE book_id = %s
""", ('B001',))
for row in rows:
print(row)
结果如下图所示:
(5)数据删除
删除book_id为B001图书的记录
session.execute("""
DELETE FROM Books WHERE book_id = %s
""", ('B001',))
执行结果如下图所示:
相关文章:
HBase Cassandra的部署和操作
目录 一.数据库的部署与配置 二.使用命令访问数据库 三.数据库的设计 四.编程实现数据库的访问 一.数据库的部署与配置 1.在单个节点上对进行数据库的单机部署 (1)下载apache-cassandra-4.1.7-…...
用户界面软件01
Jens Coldewey 著,Tom.X 译 本文中的模式语言逐步深入地探讨用户界面架构的设计,它基于人机工程学,足以形成一套完整的体系。如果你对这方面有兴趣,请参考[Tog92],[Coo95]和[Col95]。 本文不讨论用户界面的布局&…...
【云原生】Docker Compose 从入门到实战使用详解
目录 一、前言 二、Docker Compose 介绍 2.1 Docker Compose概述 2.2 Docker Compose特点 2.3 Docker Compose使用场景 三、Docker Compose 安装 3.1 安装docker环境 3.2 Docker Compose安装方式一 3.2.1 下载最新版 3.2.2 设置权限 3.2.3 设置软链接 3.2.4 查看版本…...
【ShuQiHere】使用 SCP 进行安全文件传输
【ShuQiHere】🚀 在日常的开发和运维工作中,文件传输是一个常见的任务。scp(Secure Copy)是一个基于 SSH 协议的文件传输工具,能够在本地和远程主机之间安全地复制文件和目录。本文将详细介绍 scp 的使用方法…...
海康威视H5player问题汇总大全
由于除了要支持Windows平台,还要支持国产系统的平台,这时就用到了H5player,但是这个在使用调试的时候会遇到各种各样的问题,便在此分享一下,供大家分享!!! 问题一:Unexp…...
力扣23.合并K个升序链表
文章目录 一、前言二、最小堆解法三、分治解法 一、前言 23. 合并 K 个升序链表 本题的要求是把K个链表进行合并,合并后的链表必须是从小到大的。 并且这K个链表也是从小到大的升序链表。 二、最小堆解法 既然每个链表都是升序的,也就是从小到大的。 …...
【C 语言指针篇】指针的灵动舞步与内存的神秘疆域:于 C 编程世界中领略指针艺术的奇幻华章
文章目录 【C 语言篇】指针的灵动舞步与内存的神秘疆域:于 C 编程世界中领略指针艺术的奇幻华章前言一 、指针的介绍与使用1. 指针的介绍1.1指针表示1.2指针变量1.3空指针 2. 使用指针2.1交换两个变量的值2.2计算输出最小值和最大值 二、野指针的介绍与使用1. 野指针…...
游戏关卡设计的常用模式
游戏关卡分为很多种,但常用的有固定套路,分为若干种类型。 关卡是主角与怪物、敌方战斗的场所,包括装饰物、通道。 单人游戏的关卡较小,偏线性; 联机/MMO的关卡较大,通道多,自由度高…...
在一台服务器上使用docker运行kafka集群
1.拉取镜像 docker pull wurstmeister/kafka docker pull wurstmeister/zookeeper 2.创建集群之间通信的网络 docker network create kafka-cluster-net docker network inspect kafka-cluster-net 3.将zookeeper加入到网络中 docker network connect kafka-cluster-net zooke…...
Apache Celeborn 在B站的生产实践
背景介绍 Shuffle 演进 随着B站业务的飞速发展,数据规模呈指数级增长,计算集群也逐步从单机房扩展到多机房部署模式。多个业务线依托大数据平台驱动核心业务,大数据系统的高效性与稳定性成为公司业务发展的重要基石。如图1,目前在大数据基础架构下,我们主要采用 Spark、Fl…...
JOIN 和 OUTER JOIN,SQL中常见的连接方式
1. INNER JOIN(简称 JOIN) INNER JOIN 是 SQL 中最常用的一种连接方式,默认的 JOIN 就是 INNER JOIN。它返回两个表中满足连接条件的匹配记录。 作用:返回两个表中所有满足 ON 条件的记录。特性:如果表中的某些行在连…...
Vue2: table加载树形数据的踩坑记录
table中需要加载树形数据,如图: 官网给了两个例子,且每个例子中的tree-props都是这么写的: :tree-props="{children: children, hasChildren: hasChildren}" 给我一种错觉,以为数据结构中要同时指定children和hasChildren字段,然而,在非懒加载模式下,数据结…...
电子信息硕士面试经验
回顾2024年秋招一些面试常见的问题,主要涉及软件开发和嵌入式部分内容。 1. 浅拷贝深拷贝 深拷贝和浅拷贝是两种不同的拷贝方式,用于复制对象。它们主要区别在于对嵌套对象的处理方式。 浅拷贝:只复制对象的顶层,嵌套对象仍然是共享引用。 深拷贝:递归复制所有对象及其嵌…...
dns网址和ip是一一对应的吗?
DNS网址和IP地址是一一对应的吗?我们在上网时,为什么总是使用网址而不是一串数字?这些问题其实涉及到互联网的基本运作原理。DNS(域名系统)是我们日常上网过程中一个不可或缺的部分,它帮助我们将人类易于记…...
springboot3 redis 常用操作工具类
在 Spring Boot 3 中,操作 Redis 通常使用 Spring Data Redis 提供的工具类,如 RedisTemplate 和 StringRedisTemplate。以下是一个详细的 Redis 操作工具类的实现,涵盖了常用功能。 完整的 Redis 工具类 以下工具类可以实现基本的 Redis 操…...
Java工程师实现视频文件上传minio文件系统存储及网页实现分批加载视频播放
Java工程师实现minio存储大型视频文件网页实现分批加载视频播放 一、需求说明 老板给我出个题目,让我把的电影文件上传到minio文件系统,再通过WEB端分配加载视频播放,类似于我们普通的电影网站。小编把Java代码共享出来。是真正的能拿过来直…...
Redis(二)value 的五种常见数据类型简述
目录 一、string(字符串) 1、raw 2、int 3、embstr 二、hash(哈希表) 1、hashtable 2、ziplist 三、list(列表) 编辑 1、linkedlist 2、ziplist 3、quicklist(redis 3.2后的列表内…...
Docker 环境中搭建 Redis 哨兵模式集群的步骤与问题解决
在 Docker 环境中搭建 Redis 哨兵模式集群的步骤与问题解决 在 Redis 高可用架构中,哨兵模式(Sentinel)是确保 Redis 集群在出现故障时自动切换主节点的一种机制。通过使用 Redis 哨兵,我们可以实现 Redis 集群的监控、故障检测和…...
【网页自动化】篡改猴入门教程
安装篡改猴 打开浏览器扩展商店(Edge、Chrome、Firefox 等)。搜索 Tampermonkey 并安装。 如图安装后,浏览器右上角会显示一个带有猴子图标的按钮。 创建用户脚本 已进入篡改猴管理面板点击创建 脚本注释说明 name:脚本名称。…...
【顶刊TPAMI 2025】多头编码(MHE)之极限分类 Part 4:MHE表示能力
目录 1 MHE的表示能力2 基于Frobenius-范数的低秩逼近3 基于CE的低秩近似 论文:Multi-Head Encoding for Extreme Label Classification 作者:Daojun Liang, Haixia Zhang, Dongfeng Yuan and Minggao Zhang 单位:山东大学 代码:h…...
简易版抽奖活动的设计技术方案
1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...
多场景 OkHttpClient 管理器 - Android 网络通信解决方案
下面是一个完整的 Android 实现,展示如何创建和管理多个 OkHttpClient 实例,分别用于长连接、普通 HTTP 请求和文件下载场景。 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas…...
postgresql|数据库|只读用户的创建和删除(备忘)
CREATE USER read_only WITH PASSWORD 密码 -- 连接到xxx数据库 \c xxx -- 授予对xxx数据库的只读权限 GRANT CONNECT ON DATABASE xxx TO read_only; GRANT USAGE ON SCHEMA public TO read_only; GRANT SELECT ON ALL TABLES IN SCHEMA public TO read_only; GRANT EXECUTE O…...
oracle与MySQL数据库之间数据同步的技术要点
Oracle与MySQL数据库之间的数据同步是一个涉及多个技术要点的复杂任务。由于Oracle和MySQL的架构差异,它们的数据同步要求既要保持数据的准确性和一致性,又要处理好性能问题。以下是一些主要的技术要点: 数据结构差异 数据类型差异ÿ…...
学习STC51单片机31(芯片为STC89C52RCRC)OLED显示屏1
每日一言 生活的美好,总是藏在那些你咬牙坚持的日子里。 硬件:OLED 以后要用到OLED的时候找到这个文件 OLED的设备地址 SSD1306"SSD" 是品牌缩写,"1306" 是产品编号。 驱动 OLED 屏幕的 IIC 总线数据传输格式 示意图 …...
工业自动化时代的精准装配革新:迁移科技3D视觉系统如何重塑机器人定位装配
AI3D视觉的工业赋能者 迁移科技成立于2017年,作为行业领先的3D工业相机及视觉系统供应商,累计完成数亿元融资。其核心技术覆盖硬件设计、算法优化及软件集成,通过稳定、易用、高回报的AI3D视觉系统,为汽车、新能源、金属制造等行…...
UR 协作机器人「三剑客」:精密轻量担当(UR7e)、全能协作主力(UR12e)、重型任务专家(UR15)
UR协作机器人正以其卓越性能在现代制造业自动化中扮演重要角色。UR7e、UR12e和UR15通过创新技术和精准设计满足了不同行业的多样化需求。其中,UR15以其速度、精度及人工智能准备能力成为自动化领域的重要突破。UR7e和UR12e则在负载规格和市场定位上不断优化…...
安宝特方案丨船舶智造的“AR+AI+作业标准化管理解决方案”(装配)
船舶制造装配管理现状:装配工作依赖人工经验,装配工人凭借长期实践积累的操作技巧完成零部件组装。企业通常制定了装配作业指导书,但在实际执行中,工人对指导书的理解和遵循程度参差不齐。 船舶装配过程中的挑战与需求 挑战 (1…...
c++第七天 继承与派生2
这一篇文章主要内容是 派生类构造函数与析构函数 在派生类中重写基类成员 以及多继承 第一部分:派生类构造函数与析构函数 当创建一个派生类对象时,基类成员是如何初始化的? 1.当派生类对象创建的时候,基类成员的初始化顺序 …...
深入浅出Diffusion模型:从原理到实践的全方位教程
I. 引言:生成式AI的黎明 – Diffusion模型是什么? 近年来,生成式人工智能(Generative AI)领域取得了爆炸性的进展,模型能够根据简单的文本提示创作出逼真的图像、连贯的文本,乃至更多令人惊叹的…...
