6 Hive
一、Hive 是什么
Hive 是构建在 Hadoop 之上的数据仓库平台;它通过 SQL 解析引擎把 SQL 语句转译成 MapReduce 作业,并在 Hadoop 上运行;Hive 表是 HDFS 的文件目录,一个表对应一个目录名,如果有分区,则分区值对应子目录。
二、Hive 架构
解释图中元素:
1、核心部分
1)解析器:将SQL字符串转换成抽象语法树AST,这一步一般用第三方工具完成;对AST进行语法分析,比如表是否存在、字段是否存在、SQL语义是否有误;
2)编译器:把AST翻译成逻辑执行计划,即将hql翻译成MapReduce任务;
3)优化器:对逻辑执行计划进行优化,优化方案随着模版的不断迭代而改进;
4)执行器:顺序执行所有的 job,如果 task 链不存在依赖关系,可以采用并发执行的方式执行 job。
2、元数据库
元数据用于存放 Hive 库的基础信息,它存在关系数据库中,如 mysql。元素据包括:数据库信息、表名、列表和列的分区及其属性,表的属性,表的数据所在的目录。
三、托管表与外部表
Hive 表分为两类,一个是托管表(内部表),一个是外部表。
托管表是只在 hive 中使用,外部表示 hive 之外也使用,它们下面两个方面有区别:
3.1 数据存储
托管表:数据存储在 hive 仓库目录下,是指定的。我指定为:/apps/hive/warehouse
外部表:外部表可存在 hdfs 的任意目录下。
3.2 数据删除
托管表:删除元数据和数据。
外部表:只删除元数据。
四、分区和桶
4.1 分区
分区其实就是在一个 hdfs 大的文件夹下面的子文件夹,它不是表的上面的结构,分区可以帮助我们来缩小查询的范围从而提高效率。在导入数据的时候,可以根据数据中的特定列把数据放到指定分区中,即指定文件夹中。
4.2 桶
桶是表上面的附加结构,可以提高查效率。桶对应于 MapReduce 的输出文件分区,一个作业产生的桶和 reduce 任务个数相等。
我个人理解是表对应的是文件夹,分区是文件夹下的子文件夹,而桶就是对应于子文件夹里的文件了,我们把具有相同特征的内容放到一个文件里,即一个桶中。分区针对的是数据的存储路径;分桶针对的是数据文件。
五、Hive和数据库的比较
5.1 查询语言
hive与数据库唯一相似的地方就是查询语言相似,sql和hql语法和类似
5.2 数据存储位置
hive是建立在Hadoop之上的,所以数据都是存储在hdfs中,而数据库则将数据保存在本地文件系统中。
5.3 数据更新
hive中不支持数据的更新,要想更新数据就必须先把之前的文件删除,然后再上传,而数据库则支持灵活更新。
5.4 索引
5.5 执行引擎
hive的引擎为mr、tez、spark,而数据库有自己的执行引擎。
5.6 执行延迟
hive的执行需要启动jvm和mapreduce作业,所以如果处理小规模的数据时,会明显慢于数据库;
5.7 可扩展新
因为hive构建于hadoop上,所以可以狠方面的扩展节点数量,而数据库由于ACID语义的严格限制,扩展性非常有限。
5.8 数据规模
hive支持的数据规模远远大于数据库
六、查询
6.1 排序
1. order by
全局排序,Reducer的数量一定为1,与设置的数量无关
2. sort by
每个MapReduce内部排序,Reducer的个数可以手动设置,如果设置为1,则效果和order by一样;
因为系统并不知道我们想要根据什么分区,所以默认为随机分区
3. distribute by
与 sort by 结合使用,指定分区
4. cluster by
当 sort by 的字段和 distribute by 字段相同时,可以使用 cluster by 代替
6.2 函数
1. nvl
NVL:给值为NULL的数据赋值,它的格式是NVL( string1, replace_with)。它的功能是如果string1为NULL,则NVL函数返回replace_with的值,否则返回string1的值,如果两个参数都为NULL ,则返回NULL
2. 行转列
-
concat(string A/col, string B/col···):返回输入字符串连接后的结果,支持任意个输入字符串;
- concat_ws(separator, str1, str2,…):特殊形式的concat,第一个参数指定分隔符,如果分隔符为null,返回值也为null
- collect_set(col):将某字段的值进行去重汇总,产生array类型字段
例:把星座和血型一样的人归类到一起,
name | constellation | blood_type |
---|---|---|
孙悟空 | 白羊座 | A |
大海 | 射手座 | A |
宋宋 | 白羊座 | B |
猪八戒 | 白羊座 | A |
凤姐 | 射手座 | A |
结果如下:
射手座,A 大海|凤姐
白羊座,A 孙悟空|猪八戒
白羊座,B 宋宋
解题:
select bn, concat_ws("|", collect_set(name))
from (select concat_ws(",", constellation, blood_type) bn, name from tb) t1
group by t1.bn;
3. 列转行
explode(col):将hive一列中复杂的array或者map结构拆分成多行;
lateral view:
用法:lateral view udtf(expression) tableAlias as columnAlias
解释:用于和split,explode等udtf一起使用,它能将一列数据拆分成多行数据,在此基础上可以对拆分后的数据进行聚合
例:
元数据集:
movie | category |
---|---|
《疑犯追踪》 | 悬疑,动作,科幻,剧情 |
《Lie to me》 | 悬疑,警匪,动作,心理,剧情 |
《战狼2》 | 战争,动作,灾难 |
将电影分类中的数组数据展开。结果如下:
《疑犯追踪》 悬疑
《疑犯追踪》 动作
《疑犯追踪》 科幻
《疑犯追踪》 剧情
《Lie to me》 悬疑
《Lie to me》 警匪
《Lie to me》 动作
《Lie to me》 心理
《Lie to me》 剧情
《战狼2》 战争
《战狼2》 动作
《战狼2》 灾难
解题:
-
创建hive表并导入数据,把category导入成array类型
create table movie_info(movie string, category array<string>) row format delimited fields terminated by "\t" collection items terminated by ",";load data local inpath "/opt/module/datas/movie.txt" into table movie_info;
-
查询语句
select movie, category_name from movie_info lateral view explode(category) table_tmp as category_name;
4. 窗口函数
-
over:指定分析函数的数据窗口大小,窗口大小可能会随着行的变化而变化,over 中可以指定分区和排序、
CURRENT ROW:当前行
n PRECEDING:往前n行数据
n FOLLOWING:往后n行数据
UNBOUNDED:起点,UNBOUNDED PRECEDING 表示从前面的起点, UNBOUNDED FOLLOWING表示到后面的终点
-
lag(col, n):往前第n行数据
-
lead(col, n):往后第n行数据
-
ntile(n):把有序分区中的行分发到指定数据的组中,每个组有编号,编号从1开始
-
rank():
rank():排名相同时会重复,总数不会变
dense_rand():排名相同时会重复,总数会减少
row_number():排名不重复
例1:
数据准备:
jack,2017-01-01,10
tony,2017-01-02,15
jack,2017-02-03,23
tony,2017-01-04,29
jack,2017-01-05,46
jack,2017-04-06,42
tony,2017-01-07,50
jack,2017-01-08,55
mart,2017-04-08,62
mart,2017-04-09,68
neil,2017-05-10,12
mart,2017-04-11,75
neil,2017-06-12,80
mart,2017-04-13,94
需求:
(1)查询在2017年4月份购买过的顾客及总人数
(2)查询顾客的购买明细及月购买总额
(3)上述的场景,要将cost按照日期进行累加
(4)查询顾客上次的购买时间
(5)查询前20%时间的订单信息
创建hive表并导入数据
create table business(
name string,
orderdate string,
cost int
) ROW FORMAT DELIMITED FIELDS TERMINATED BY ',';load data local inpath "/opt/module/datas/business.txt" into table business;
(1)查询在2017年4月份购买过的顾客及总人数
selectname,count(*) over()
from business
where substring(orderdate, 1, 7) = '2017-04'
group by name;
(2)查询顾客的购买明细及月购买总额
select name,orderdate,cost,sum(cost) over(partition by month(orderdate))
from business;
(3)上述的场景,要将cost按照日期进行累加
select name,orderdate,cost, sum(cost) over() as sample1,--所有行相加 sum(cost) over(partition by name) as sample2,--按name分组,组内数据相加 sum(cost) over(partition by name order by orderdate) as sample3,--按name分组,组内数据累加 sum(cost) over(partition by name order by orderdate rows between UNBOUNDED PRECEDING and current row ) as sample4 ,--和sample3一样,由起点到当前行的聚合 sum(cost) over(partition by name order by orderdate rows between 1 PRECEDING and current row) as sample5, --当前行和前面一行做聚合 sum(cost) over(partition by name order by orderdate rows between 1 PRECEDING AND 1 FOLLOWING ) as sample6,--当前行和前边一行及后面一行 sum(cost) over(partition by name order by orderdate rows between current row and UNBOUNDED FOLLOWING ) as sample7 --当前行及后面所有行
from business;
(4)查询顾客上次购买的时间
select name,orderdate,lag(orderdate, 1, '1900-01-01') over(partition by name order by orderdate)
from business;
(5)查询前20%时间的订单信息
select *
from (select name, orderdate,ntile(5) over(order by orderdate) sortedfrom business) t1
where sorted = 1;
例2:
数据准备:
name | subject | score |
---|---|---|
孙悟空 | 语文 | 87 |
孙悟空 | 数学 | 95 |
孙悟空 | 英语 | 68 |
大海 | 语文 | 94 |
大海 | 数学 | 56 |
大海 | 英语 | 84 |
宋宋 | 语文 | 64 |
宋宋 | 数学 | 86 |
宋宋 | 英语 | 84 |
婷婷 | 语文 | 65 |
婷婷 | 数学 | 85 |
婷婷 | 英语 | 78 |
需求:
计算每门学科成绩排名。
创建hive表并导入数据
create table score(
name string,
subject string,
score int)
row format delimited fields terminated by "\t";
load data local inpath '/opt/module/datas/score.txt' into table score;
查询语句
select name,subject,score,rank() over(partition by subject order by score desc),dense rank() over(partition by subject order by score desc) drp,row_number() over(partition by subject order by score desc) rmp
from score;
结果:
name subject score rp drp rmp
孙悟空 数学 95 1 1 1
宋宋 数学 86 2 2 2
婷婷 数学 85 3 3 3
大海 数学 56 4 4 4
宋宋 英语 84 1 1 1
大海 英语 84 1 1 2
婷婷 英语 78 3 2 3
孙悟空 英语 68 4 3 4
大海 语文 94 1 1 1
孙悟空 语文 87 2 2 2
婷婷 语文 65 3 3 3
宋宋 语文 64 4 4 4
七、存储和压缩
7.1 存储格式
1.行式存储和列式存储
(行式存储和列式存储)
行式存储:当查询满足条件的一整行数据时,行式存储的速度更快,因为列式存储需要去每个字段聚集的地方寻找对应的列,而行式存储只需要找到其中一个字段,其余字段都在附近的地方。
列式存储:因为每个字段都聚集存储,所以如果查询少数几个字段时,可以大大减少读取的数据量。
2. TextFile格式
TextFile每一行是一条记录,每行都以\n结尾。数据不做压缩,磁盘开销大,数据解析开销大。
3. SequenceFile格式
SequenceFile是Hadoop API提供的一种二进制文件支持,使用方便、可分割,可压缩。
4. Orc格式
Orc提供了一种将数据存储在hive表中的高效方法。该存储格式是为了克服其他存储格式的缺点而设计的,所以在hive中具有最高的性能,以及最小的存储空间。
5. Parquet格式
Parquet是一个面向列的二进制存储格式,是spark的默认存储格式,所以使用parquet可以极大地优化spark地调度和执行。
存储格式 | 存储方式 | 特点 |
---|---|---|
TextFile | 行存储 | 存储空间消耗比较大,并且压缩地text无法分割和合并,查询效率最低 |
SequenceFile | 行存储 | 存储空间消耗最大,压缩地文件可以分割和合并,查询效率高 |
Orc | 行列结合,数据按行分块,每块按列存储 | 存储空间消耗最小,查询效率最高 |
Parquet | 列存储 | 相较于Orc,Parquet空间消耗较大,查询效率较低,但是在spark on hive的情况下,性能最好 |
7.2 压缩格式
1. 为什么使用压缩
- 节省数据占用的磁盘空间
- 加快数据在磁盘和网络中的传输速度,从而提高系统的处理速度
2. 常用压缩格式的对比
-
特性对比
压缩格式 codec类 算法 扩展名 多文件 splitable native hadoop自带 deflate DeflateCodec deflate .deflate 否 否 是 是 gzip GzipCodec deflate .gz 否 否 是 是 bzip2 Bzip2Codec bzip2 .bz2 是 是 否 是 lzo LzopCodec lzo .lzo 否 是 是 否 snappy SnappyCodec snappy .snappy 否 否 是 否 文件的可分割性在 Hadoop 中是很非常重要的,它会影响到在执行作业时 Map 启动的个数,从而会影响到作业的执行效率!
-
性能对比
压缩格式 压缩比 压缩速率 解压速率 gzip/deflate 13.4% 21MB/s 118MB/s bzip2 13.2% 2.4MB/s 9.5MB/s lzo 20.5% 135MB/s 410MB/s snappy 22.2% 172MB/s 409MB/s
3. 使用情景
- gzip
- 当每个文件压缩之后在一个块大小内,可以考虑用gzip压缩格式。
- bzip2
- 对速度要求不高,但需要较高压缩率并且需要支持split的情况
- lzo
- 一个很大的文本文件,压缩之后还大于200M的可以考虑用lzo,而且单个文件越大,lzo的优点越明显
- snappy
- map输出的数据比较大的时候,作为map到reduce的中间数据压缩格式
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- 《深入浅出强化学习》知识框架
《强化学习》 基于动态规划的强化学习 强化学习的目标是找到最优策略使得该策略下的累计回报期望最大。所谓策略指状态到动作的映射π。 最常用的概率分布也就是最常用的随机策略。如贪婪策略、ε-greedy策略、高斯策略、玻尔兹曼策略等。 最优策略的目标是找到一个决策序列u0→…...
2024/4/7 21:52:44 - JavaScript介绍
JavaScript是什么 历史 Netscape在最初将其脚本语言命名为LiveScript,后来Netscape在与Sun合作之后将其改名为JavaScript。JavaScript最初受Java启发而开始设计的,目的之一就是“看上去像Java”,因此语法上有类似之处,一些名称和命名规范也借自Java。JavaScript与Java名称上…...
2024/5/1 22:17:00 - alin的学习之路(数据库篇:四)(oracle数据库表的操作,oracle其他对象:视图、索引、序列、同义词)
alin的学习之路(数据库篇:四)(oracle数据库表的操作,oracle其他对象:视图、索引、序列、同义词) 1. oracle数据库表的操作 数据库表是基本的数据存储集合,由行和列组成。 数据库的表要注意命名规则:必须以字母开头 必须在 1–30 个字符之间 允许包含的字符: A–Z, a–…...
2024/4/4 11:02:16 - 动态规划之合并石子
动态规划——合并石子(C语言解) 第一次接触到动态规划是在斐波那契数列,那个时候还不知道动态规划的概念,由于数据量较小,直接用for循环就通过了,直到遇到了”合并石子“这道题目,百度过很多的文章都没看懂,大佬们都讲得太抽象了,一上来就是状态改变方程,算法小白一脸…...
2024/5/1 3:41:31 - 大数据学习(五):如何使用 Livy提交spark批量任务--转载
Livy是一个开源的REST 接口,用于与Spark进行交互,它同时支持提交执行代码段和完整的程序。Livy封装了spark-submit并支持远端执行。启动服务器执行以下命令,启动livy服务器。./bin/livy-server这里假设spark使用yarn模式,所以所有文件路径都默认位于HDFS中。如果是本地开发…...
2024/5/1 22:27:56 - 十大排序算法
算法的时间复杂度并不能代表算法的实际执行时间,有些时候看似复杂度高的速度反面快。 查找算法: 顺序查找: 对待查找的数据没有要求,时间复杂度: O(n) 二分查找: 对待查找的数据必须有序,时间复杂度: O(logn) 块查找: 是一种数据处理的思想,不是特定的算法,当数据量过多…...
2024/4/4 11:22:10 - 苹果cms 大橙子模板 魔改版本
苹果cms 大橙子模板 魔改版本演示站:西瓜影视 http://www.xigua57.com修改:首页、分类页轮播图修改 修改排行榜 修改导航 修改影视专题展示 增加预告片 播放器修改、增加弹幕播放器 增加面包屑导航 布局hits算法 全站nofollow优化 等seo优化网站部分截图:首页截图黑色主题:…...
2024/5/1 22:11:29 - linux文件编程 打开 创建 写入
int main() {int fd;fd = open("./file2",O_RDWR);if(fd == -1){printf("file2 no exist\n");}fd = open("./file2",O_RDWR|O_CREAT,0600);if(fd > 0){printf("file2 okok\n");}return 0; }linux 文件编程int main() {int fd;char …...
2024/4/4 11:22:08 - django流程
一:urls.py二:views.py def hello(request): return render(request, “hello.html”) (先不用models如下:1.HttpResponse()或者render()2.templates)注意:创建文件夹templates,并将其标记成如下,此时文件夹会显示为紫色三 添加model: 1.这里的设置就像mysql,Book用继…...
2024/4/4 11:22:06 - HTTP/1.1 报文结构
文章目录HTTP 协议HTTP/1.1 报文结构HTTP/1.1 请求HTTP/1.1 应答 HTTP 协议HTTP (Hypertext Transfer Protocol, 超文本传输协议) 是常见的应用层传输协议。该协议有诸多版本,目前应用最广泛的为 HTTP/1.1 版本。HTTP/0.9 和 HTTP/1.0版本,目前已很少应用,除非研究 HTTP协议…...
2024/4/4 11:22:07 - 成为 Kafka 高手的秘籍:生产者深度实践总结
Kafka 简介kafka 是一款已经发布了近10年的分布式消息队列系统,是一款非常成熟的产品,在各大公司或者产品中或多或少都有他的身影,特别是大数据流处理,log 流处理之类的场景,kafka 更是充当着几乎必不可少的角色。这款消息队列在官方给出的定义中被称为“分布式流式处理平…...
2024/4/28 5:51:43 - 慕课网 前端就业班 float浮动 编程练习 3-5
3-5 编程练习 我们学习了浮动的知识,那么我们来实现图文混排的效果如下图所示:图片素材: 图1 图2 任务 1、首先给大的容器content设置基本样式,宽度为810px,高度自适应,居中显示,字体为微软雅黑,行高为24px,边距、边框等设置。 2、想要实现文字环绕图片,实现图文混排…...
2024/4/24 22:54:37 - web特效-折叠隐藏文字&炫酷复选框&波动加载条&音乐波动加载条&流彩边框&环形指示器
web特效 折叠隐藏文字<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><title>被折叠隐藏的字符</title><style>*{margin: 0px;padding: 0px;}.char1{background-color: red;margin: auto;borde…...
2024/4/4 11:22:04 - NOI2020 游记
NOI2020 游记 我是 BJ D 类,没实力的氪金选手。 Day -1 APIO 炸沉,此处略去不计。 下午 Mr_Wu 讲二分图讲得天花乱坠,体验极其欠佳,但是仍然学到很多。 Day 0 报道日。 一大早起来等火车,EI,xtq 等人陆续到来,压力爆满。 候车室分成北大附,人大附和十一的《三国》。八十…...
2024/4/4 11:22:01 - RabbitMQ安装和配置
安装包Erlang:erlang-23.0.2-1.el7.x86_64RabbitMQ:rabbitmq-server-3.8.4-1.el7.noarchRabbitMQ的安装需要首先安装Erlang,因为它是基于Erlang的VM运行的。 RabbitMQ需要的依赖:socat和logrotate,logrotate操作系统中已经存在了,只需要安装socat就 可以了。RabbitMQ与Er…...
2024/4/7 1:33:37 - PHP Opcache 注意细节以及调优办法
从 PHP5.5 开始,Opcache 扩展是核心的一部分,增加了对 PHP 脚本的字节码缓存的支持。对于动态语言(例如 PHP ),字节码缓存可以显著的提高性能,因为它可以确保脚本仅被编译一次。Opcache 扩展的默认设置已经在很大程度上提高了 PHP 的性能,但是您可以通过修改默认配置以获…...
2024/4/4 11:21:59 - 超级大洋葱和你一起学习C++(7):C++头文件
main.cpp: #include<iostream>//C++的头文件,不带.h #include<cstdio> // C的头文件,去掉.h,前面加上c #include "test.h" //如果是自定义头文件,需要加.h #include "test.h" //重复包含头文件 using namespace std;int main() {cout…...
2024/4/8 18:12:29 - Nginx + PHP-fpm File not found.问题解决记录(收藏)
这篇文章介绍的内容是关于Nginx + PHP-fpm File not found.问题解决记录,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下现象确认:打开浏览器的开发者工具,查看请求信息粉丝福利,感谢大家一直以来的支持,特此整理了进阶资料分享给大家,大厂必备面试题:面…...
2024/4/4 11:21:57 - PHP 中使用 TUS 协议来实现大文件的断点续传(收藏一波)
你是否曾经为大文件上传而苦恼?如果文件上传的过程中,因为某种原因中断了,是否可以从中断的位置继续上传,而不用重新上传整个文件?如果你有这样的困惑,那么请继续阅读下面的内容。在现代网站应用中,上传文件是非常常见的。在任何语言中,通过使用一些工具,都可以实现文…...
2024/4/4 11:21:56 - 超级大洋葱和你一起学习C++(8):命名空间namespace
示例代码: #include<iostream> using namespace std;//使用std名字空间下的所有变量int a = 100;namespace A {int a = 200;int b = 300;namespace B//名字空间的嵌套{int b = 400;int z = 900;}namespace B//可以重复定义命名空间,相当于扩充{int m= 80…...
2024/4/4 7:36:23
最新文章
- AI泳池溺水监测识别摄像机
AI泳池溺水监测识别摄像机是一种利用人工智能和机器视觉技术的创新设备,旨在确保游泳池安全,并及时识别溺水事件,以减少溺水事故的发生。这种摄像机利用高清摄像头和AI算法,能够实时监测泳池中的情况,并自动识别溺水事…...
2024/5/2 0:38:57 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - dp小兰走迷宫
昨天学习了bfs的基本概念,今天来做一道经典习题练练手吧! bfs常用的两类题型 1.从A出发是否存在到达B的路径(dfs也可) 2.从A出发到B的最短路径(数小:<20才能用dfs) 遗留的那个问题的答案- 题目:走迷宫 #incl…...
2024/5/1 8:48:43 - 如何转行成为产品经理?
转行NPDP也是很合适的一条发展路径,之后从事新产品开发相关工作~ 一、什么是NPDP? NPDP 是产品经理国际资格认证,美国产品开发与管理协会(PDMA)发起的,是目前国际公认的唯一的新产品开发专业认证ÿ…...
2024/5/1 13:02:24 - 416. 分割等和子集问题(动态规划)
题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义:dp[i][j]表示当背包容量为j,用前i个物品是否正好可以将背包填满ÿ…...
2024/5/1 10:25:26 - 【Java】ExcelWriter自适应宽度工具类(支持中文)
工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...
2024/5/1 13:20:04 - Spring cloud负载均衡@LoadBalanced LoadBalancerClient
LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon,直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件,我们讨论Spring负载均衡以Spring Cloud2020之后版本为主,学习Spring Cloud LoadBalance,暂不讨论Ribbon…...
2024/5/1 21:18:12 - TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案
一、背景需求分析 在工业产业园、化工园或生产制造园区中,周界防范意义重大,对园区的安全起到重要的作用。常规的安防方式是采用人员巡查,人力投入成本大而且效率低。周界一旦被破坏或入侵,会影响园区人员和资产安全,…...
2024/5/1 4:07:45 - VB.net WebBrowser网页元素抓取分析方法
在用WebBrowser编程实现网页操作自动化时,常要分析网页Html,例如网页在加载数据时,常会显示“系统处理中,请稍候..”,我们需要在数据加载完成后才能继续下一步操作,如何抓取这个信息的网页html元素变化&…...
2024/4/30 23:32:22 - 【Objective-C】Objective-C汇总
方法定义 参考:https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...
2024/4/30 23:16:16 - 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】
👨💻博客主页:花无缺 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】🌏题目描述🌏输入格…...
2024/5/1 6:35:25 - 【ES6.0】- 扩展运算符(...)
【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数࿰…...
2024/5/1 11:24:00 - 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?
文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕,各大品牌纷纷晒出优异的成绩单,摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称,在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁,多个平台数据都表现出极度异常…...
2024/5/1 4:35:02 - Go语言常用命令详解(二)
文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令,这些命令可以帮助您在Go开发中进行编译、测试、运行和…...
2024/5/1 20:22:59 - 用欧拉路径判断图同构推出reverse合法性:1116T4
http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b,我们在 a i a_i ai 和 a i 1 a_{i1} ai1 之间连边, b b b 同理,则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然࿰…...
2024/4/30 22:14:26 - 【NGINX--1】基础知识
1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息,并安装一些有助于配置官方 NGINX 软件包仓库的软件包: apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...
2024/5/1 6:34:45 - Hive默认分割符、存储格式与数据压缩
目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限(ROW FORMAT)配置标准HQL为: ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...
2024/5/2 0:07:22 - 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法
文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中,传感器和控制器产生大量周…...
2024/4/30 20:39:53 - --max-old-space-size=8192报错
vue项目运行时,如果经常运行慢,崩溃停止服务,报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中,通过JavaScript使用内存时只能使用部分内存(64位系统&…...
2024/5/1 4:45:02 - 基于深度学习的恶意软件检测
恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞,例如可以被劫持的合法软件(例如浏览器或 Web 应用程序插件)中的错误。 恶意软件渗透可能会造成灾难性的后果,包括数据被盗、勒索或网…...
2024/5/1 8:32:56 - JS原型对象prototype
让我简单的为大家介绍一下原型对象prototype吧! 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定,每一个构造函数都有一个 prototype 属性,指向另一个对象,所以我们也称为原型对象…...
2024/5/1 14:33:22 - C++中只能有一个实例的单例类
C中只能有一个实例的单例类 前面讨论的 President 类很不错,但存在一个缺陷:无法禁止通过实例化多个对象来创建多名总统: President One, Two, Three; 由于复制构造函数是私有的,其中每个对象都是不可复制的,但您的目…...
2024/5/1 11:51:23 - python django 小程序图书借阅源码
开发工具: PyCharm,mysql5.7,微信开发者工具 技术说明: python django html 小程序 功能介绍: 用户端: 登录注册(含授权登录) 首页显示搜索图书,轮播图࿰…...
2024/5/1 5:23:20 - 电子学会C/C++编程等级考试2022年03月(一级)真题解析
C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...
2024/5/1 20:56:20 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57