大数据学习:hive的DQL和DML操作

news2025/1/22 9:12:19

hive的DQL和DML操作

1. Hive的分桶表

1.1 分桶表原理

  • 分桶是相对分区进行更细粒度的划分

    • Hive表或分区表可进一步的分桶

    • 分桶将整个数据内容按照某列取hash值,对桶的个数取模的方式决定该条记录存放在哪个桶当中;具有相同hash值的数据进入到同一个文件中

    • 比如按照name属性分为3个桶,就是对name属性值的hash值对3取摸,按照取模结果对数据分桶。

      • 取模结果为0的数据记录存放到一个文件

      • 取模结果为1的数据记录存放到一个文件

      • 取模结果为2的数据记录存放到一个文件

1.2 作用

  • 1、取样sampling更高效。没有分桶的话需要扫描整个数据集。

  • 2、提升某些查询操作效率,例如map side join

1.3 案例演示:创建分桶表

  • 在创建分桶表之前要执行的命令

  • set hive.enforce.bucketing=true; 开启对分桶表的支持

  • set mapreduce.job.reduces=4; 设置与桶相同的reduce个数(默认只有一个reduce)

  • 进入hive客户端然后执行以下命令

use myhive;
set hive.enforce.bucketing=true; 
set mapreduce.job.reduces=4;  

-- 创建分桶表
create table myhive.user_buckets_demo(id int, name string)
clustered by(id) 
into 4 buckets 
row format delimited fields terminated by '\t';

-- 创建普通表
create table user_demo(id int, name string)
row format delimited fields terminated by '\t';
  • 准备数据文件 buckets.txt
#在linux当中执行以下命令
cd /opt/install/hivedatas/
vim user_bucket.txt

1	anzhulababy1
2	anzhulababy2
3	anzhulababy3
4	anzhulababy4
5	anzhulababy5
6	anzhulababy6
7	anzhulababy7
8	anzhulababy8
9	anzhulababy9
10	anzhulababy10
  • 加载数据到普通表 user_demo 中
load data local inpath '/opt/install/hivedatas/user_bucket.txt'  overwrite into table user_demo; 
  • 4、加载数据到桶表user_buckets_demo中
insert into table user_buckets_demo select * from user_demo;
  • hdfs上查看表的数据目录

  • 抽样查询桶表的数据
    • 官网地址
    • tablesample抽样语句语法:tablesample(bucket x out of y)
      • x表示从第几个桶开始做数据采样
    • y与进行采样的桶数的个数、每个采样桶的采样比例有关;
  select * from user_buckets_demo ;
需要采样的总桶数 = 分桶数/y = 结果ret
分两种情况

情况一:ret>1
需要采样的总桶数 = 分桶数/y = 4/2 = 2个
即从2个桶进行数据的采样
x = 1 先从第1个桶中取出数据
x+y = 1+2 = 3 再从第3个桶中取出数据

情况二:ret<1
假设还是此表user_buckets_demo,分桶数是4
x=1
y=8
∴需要采样的总桶数 = 分桶数/y = 4/8 = 0.5
ret<1,只能从1个桶进行数据的采样
x = 1 从第1个桶中取出0.5一半的数据

2. Hive数据导入

2.1 直接向表中插入数据

hive (myhive)> create table score3 like score;
hive (myhive)> insert into table score3 partition(month ='201807') values ('001','002','100');

2.2 通过load加载数据

  • 语法:
 hive> load data [local] inpath 'dataPath' [overwrite] into table student [partition (partcol1=val1,)]; 
  • 通过load方式加载数据
hive (myhive)> load data local inpath '/opt/install/hivedatas/score.csv' overwrite into table score partition(month='201806');

2.3 通过查询加载数据

  • 通过查询方式加载数据
  • 语法;官网地址
INSERT OVERWRITE TABLE tablename1 [PARTITION (partcol1=val1, partcol2=val2 ...) [IF NOT EXISTS]] select_statement1 FROM from_statement;
INSERT INTO TABLE tablename1 [PARTITION (partcol1=val1, partcol2=val2 ...)] select_statement1 FROM from_statement;
  • 例子
hive (myhive)> create table score5 like score;
hive (myhive)> insert overwrite table score5 partition(month = '201806') select s_id,c_id,s_score from score;

2.4 查询语句中创建表并加载数据(as select)

  • 将查询的结果保存到一张表当中去
hive (myhive)> create table score6 as select * from score;

2.5 创建表时指定location

  • 创建表,并指定在hdfs上的位置
hive (myhive)> create external table score7 (s_id string,c_id string,s_score int) row format delimited fields terminated by '\t' location '/myscore7';
  • 上传数据到hdfs上,我们也可以直接在hive客户端下面通过dfs命令来进行操作hdfs的数据
hive (myhive)> dfs -mkdir -p /myscore7;
hive (myhive)> dfs -put /opt/install/hivedatas/score.csv /myscore7;
  • 查询数据
hive (myhive)> select * from score7;

2.6 export导出与import 导入 hive表数据(内部表操作)

hive (myhive)> create table teacher2 like teacher;
-- 导出到hdfs路径
hive (myhive)> export table teacher to  '/opt/teacher';
hive (myhive)> import table teacher2 from '/opt/teacher';

3. Hive数据导出

3.1 insert 导出

  • 表 -> 文件
  • 官方文档
  • 语法
INSERT OVERWRITE [LOCAL] DIRECTORY directory1
  [ROW FORMAT row_format] [STORED AS file_format] (Note: Only available starting with Hive 0.11.0)
  SELECT ... FROM ...
  • 将查询的结果导出到本地
insert overwrite local directory '/opt/install/hivedatas/stu' select * from stu;
  • 将查询的结果格式化导出到本地
insert overwrite local directory '/opt/install/hivedatas/stu2' row format delimited fields terminated by ',' select * from stu;
  • 将查询的结果导出到HDFS上(没有local)
insert overwrite directory '/opt/hivedatas/stu' row format delimited fields terminated by  ','  select * from stu;

3.2 Hive Shell 命令导出

  • 基本语法:

    • hive -e “sql语句” > file
    • hive -f sql文件 > file
    • 在linux命令行中,运行如下命令;导出myhive.stu表的数据到本地磁盘文件/opt/install/hivedatas/student1.txt
hive -e 'select * from myhive.stu;' > /opt/install/hivedatas/student1.txt

3.3 export导出到HDFS上

export table  myhive.stu to '/opt/install/hivedatas/stuexport';

4. Hive的静态分区和动态分区

4.1 静态分区

  • 表的分区字段的值需要开发人员手动给定

  • 创建分区表

use myhive;
create table order_partition(
order_number string,
order_price  double,
order_time string
)
partitioned BY(month string)
row format delimited fields terminated by '\t';
  • 准备数据
cd /opt/install/hivedatas
vim order.txt 

10001	100	2019-03-02
10002	200	2019-03-02
10003	300	2019-03-02
10004	400	2019-03-03
10005	500	2019-03-03
10006	600	2019-03-03
10007	700	2019-03-04
10008	800	2019-03-04
10009	900	2019-03-04
  • 加载数据到分区表
load data local inpath '/opt/install/hivedatas/order.txt' overwrite into table order_partition partition(month='2019-03');
  • 4、查询结果数据
select * from order_partition where month='2019-03';
结果为:
  
10001   100.0   2019-03-02      2019-03
10002   200.0   2019-03-02      2019-03
10003   300.0   2019-03-02      2019-03
10004   400.0   2019-03-03      2019-03
10005   500.0   2019-03-03      2019-03
10006   600.0   2019-03-03      2019-03
10007   700.0   2019-03-04      2019-03
10008   800.0   2019-03-04      2019-03
10009   900.0   2019-03-04      2019-03

4.2 动态分区

  • 按照需求实现把数据自动导入到表的相应分区中,不需要手动指定分区字段的值

  • 需求:根据分区字段不同的值,自动将数据导入到分区表不同的分区中

  • 创建表

--创建普通表
create table t_order(
    order_number string,
    order_price  double, 
    order_time   string
)row format delimited fields terminated by '\t';

--创建目标分区表
create table order_dynamic_partition(
    order_number string,
    order_price  double    
)partitioned BY(order_time string)
row format delimited fields terminated by '\t';
  • 准备数据
cd /opt/install/hivedatas
vim order_partition.txt

10001	100	2019-03-02 
10002	200	2019-03-02
10003	300	2019-03-02
10004	400	2019-03-03
10005	500	2019-03-03
10006	600	2019-03-03
10007	700	2019-03-04
10008	800	2019-03-04
10009	900	2019-03-04
  • 向普通表t_order加载数据
load data local inpath '/opt/install/hivedatas/order_partition.txt' overwrite into table t_order;
  • 动态加载数据到分区表中
-- 要想进行动态分区,需要设置参数
-- 开启动态分区功能
hive> set hive.exec.dynamic.partition=true; 
-- 设置hive为非严格模式
hive> set hive.exec.dynamic.partition.mode=nonstrict; 
-- 动态分区是通过位置来对应分区值的。原始表select出来的值和输出partition的值的关系仅仅是通过位置来确定的,和名字并没有关系,比如此例中的order_time
hive> insert into table order_dynamic_partition partition(order_time) select order_number, order_price, order_time from t_order;
  • 查看分区
hive> show partitions order_dynamic_partition;

扩展:混用动态分区、静态分区

--创建目标分区表
create table order_dynamic_partition1(
    order_number string,
    order_price  double    
)partitioned BY(year string, month string, day string)
row format delimited fields terminated by '\t';

hive> insert into table order_dynamic_partition1 partition(year='2019', month='03', day) select order_number, order_price, day(order_time) from t_order where year(order_time)`'2019' and month(order_time)`'03';

5. Hive的查询语法

5.1 基本查询

  • 注意
    • SQL 语言大小写不敏感
    • SQL 可以写在一行或者多行
    • 关键字不能被缩写也不能分行
    • 各子句一般要分行写
    • 使用缩进提高语句的可读性

5.1.1 查询全表和特定列

  • 全表查询
select * from stu;
  • 选择特定列查询
select id,name from stu;

5.1.2 列起别名

  • 重命名一个列

    • 紧跟列名,也可以在列名和别名之间加入关键字 ‘as’
  • 案例实操

select id,name as stuName from stu;

5.1.3 常用函数

  • 求总行数(count)
 select count(*) cnt from score;
  • 求分数的最大值(max)
select max(s_score) from score;
  • 求分数的最小值(min)
select min(s_score) from score;
  • 求分数的总和(sum)
select sum(s_score) from score;
  • 求分数的平均值(avg)
select avg(s_score) from score;

5.1.4 limit 语句

  • imit子句用于限制返回的行数。
 select  * from score limit 5;

5.1.5 where 语句

  • 使用 where 子句,将不满足条件的行过滤掉
  • where 子句紧随from子句
  • 案例实操
select * from score where s_score > 60;

5.1.6 算术运算符

运算符描述
A+BA和B 相加
A-BA减去B
A*BA和B 相乘
A/BA除以B
A%BA对B取余
A&BA和B按位取与
A|BA和B按位取或
A^BA和B按位取异或
~AA按位取反

5.1.7 比较运算符

操作符支持的数据类型描述
A=B基本数据类型如果A等于B则返回true,反之返回false
A<=>B基本数据类型如果A和B都为NULL,则返回true,其他的和等号(=)操作符的结果一致,如果任一为NULL则结果为NULL
A<>B, A!=B基本数据类型A或者B为NULL则返回NULL;如果A不等于B,则返回true,反之返回false
A<B基本数据类型A或者B为NULL,则返回NULL;如果A小于B,则返回true,反之返回false
A<=B基本数据类型A或者B为NULL,则返回NULL;如果A小于等于B,则返回true,反之返回false
A>B基本数据类型A或者B为NULL,则返回NULL;如果A大于B,则返回true,反之返回false
A>=B基本数据类型A或者B为NULL,则返回NULL;如果A大于等于B,则返回true,反之返回false
A [NOT] BETWEEN B AND C基本数据类型如果A,B或者C任一为NULL,则结果为NULL。如果A的值大于等于B而且小于或等于C,则结果为true,反之为false。如果使用NOT关键字则可达到相反的效果。
A IS NULL所有数据类型如果A等于NULL,则返回true,反之返回false
A IS NOT NULL所有数据类型如果A不等于NULL,则返回true,反之返回false
IN(数值1, 数值2)所有数据类型使用 IN运算显示列表中的值
A [NOT] LIKE BSTRING 类型B是一个SQL下的简单正则表达式,如果A与其匹配的话,则返回true;反之返回false。B的表达式说明如下:‘x%’表示A必须以字母‘x’开头,‘%x’表示A必须以字母’x’结尾,而‘%x%’表示A包含有字母’x’,可以位于开头,结尾或者字符串中间。如果使用NOT关键字则可达到相反的效果。like不是正则,而是通配符
A RLIKE B, A REGEXP BSTRING 类型B是一个正则表达式,如果A与其匹配,则返回true;反之返回false。匹配使用的是JDK中的正则表达式接口实现的,因为正则也依据其中的规则。例如,正则表达式必须和整个字符串A相匹配,而不是只需与其字符串匹配。

5.1.8 逻辑运算符

操作符操作描述
A AND B逻辑并如果A和B都是true则为true,否则false
A OR B逻辑或如果A或B或两者都是true则为true,否则false
NOT A逻辑否如果A为false则为true,否则false

5.2 分组

5.2.1 Group By 语句

  • Group By语句通常会和聚合函数一起使用,按照一个或者多个列对结果进行分组,然后对每个组执行聚合操作。

  • Group By时select后的字段要么是分组字段、要么是聚合函数

  • 查询非分组字段会报错

  • 案例实操:

    • 计算每个学生的平均分数
    select s_id, avg(s_score) from score group by s_id;
    
    • 计算每个学生最高的分数
    select s_id, max(s_score) from score group by s_id;
    

5.2.2 Having语句

  • having 与 where 不同点

    • where针对表中的列发挥作用,查询数据;having针对查询结果中的列发挥作用,筛选数据
    • where后面不能写聚合函数,而having后面可以使用聚合函数
    • having只用于group by分组统计语句
  • 案例实操

    • 求每个学生的平均分数
    select s_id, avg(s_score) from score group by s_id;
    
    • 求每个学生平均分数大于60的人
    select s_id, avg(s_score) as avgScore from score group by s_id having avgScore > 60;
    等价于
    select s_id, avg(s_score) as avgScore from score group by s_id having avg(s_score) > 60;
    

5.3 join语句

5.3.1 等值 join

  • Hive支持通常的SQL JOIN语句,但是只支持等值连接,不支持非等值连接

  • 案例实操

    • 根据学生和成绩表,查询学生姓名对应的成绩
    select * from stu left join score on stu.id = score.s_id;
    

5.3.2 表的别名

  • 好处

    • 使用别名可以简化查询。
    • 使用表名前缀可以提高执行效率。
  • 案例实操:合并老师与课程表

    -- hive当中创建course表并加载数据
    create table course (c_id string, c_name string, t_id string) 
    row format delimited fields terminated by '\t';
    
    load data local inpath '/opt/install/hivedatas/course.csv' overwrite into table course;
    
    select * from teacher t join course c on t.t_id = c.t_id;
    

5.3.3 内连接 inner join

  • 内连接:只有进行连接的两个表中都存在与连接条件相匹配的数据才会被保留下来。

    • join默认是inner join
  • 案例实操

    select * from teacher t inner join course c  on t.t_id = c.t_id;
    

5.3.4 左外连接 left outer join

  • 左外连接:

    • join操作符左边表中符合where子句的所有记录将会被返回。
    • 右边表的指定字段没有符合条件的值的话,那么就使用null值替代。
  • 案例实操:查询老师对应的课程

     select * from teacher t left outer join course c on t.t_id = c.t_id;
    

5.3.5 右外连接 right outer join

  • 右外连接:

    • join操作符右边表中符合where子句的所有记录将会被返回。
    • 左边表的指定字段没有符合条件的值的话,那么就使用null值替代。
  • 案例实操

     select * from teacher t right outer join course c on t.t_id = c.t_id;
    

5.3.6 满外连接 full outer join

  • 满外连接:

    • 将会返回所有表中符合where语句条件的所有记录。
    • 如果任一表的指定字段没有符合条件的值的话,那么就使用null值替代。
  • 案例实操

    select * from teacher t full outer join course c on t.t_id = c.t_id;
    

5.3.7 多表连接

  • 多个表使用join进行连接

  • 注意:连接 n个表,至少需要n-1个连接条件。例如:连接三个表,至少需要两个连接条件。

  • 案例实操

    • 多表连接查询,查询老师对应的课程,以及对应的分数,对应的学生
    select * from teacher t 
    left join course c on t.t_id = c.t_id 
    left join score s on c.c_id = s.c_id 
    left join stu on s.s_id = stu.id;
    

5.4 排序

  • 官网文档

5.4.1 order by 全局排序

  • 全局排序,只有一个reduce

  • 使用 ORDER BY 子句排序

    • asc ( ascend) 升序 (默认)
    • desc (descend) 降序
  • order by 子句在select语句的结尾

  • 案例实操

    • 查询学生的成绩,并按照分数降序排列
    select * from score s order by s_score desc ;
    

5.4.2 按照别名排序

  • 按照学生分数的平均值排序

    select s_id, avg(s_score) avgscore from score group by s_id order by avgscore desc; 
    

5.4.3 每个MapReduce内部排序(Sort By)局部排序

  • sort by:每个reducer内部有序排序(局部有序),对全局结果集来说并非全局有序。

  • 设置reduce个数

    set mapreduce.job.reduces=3;
    
  • 查看reduce的个数

    set mapreduce.job.reduces;
    
  • 查询成绩按照成绩降序排列

    select * from score s sort by s.s_score;
    
  • 将查询结果导入到文件中(按照成绩降序排列)

    insert overwrite local directory '/opt/install/hivedatas/sort' select * from score s sort by s.s_score;
    

5.4.4 distribute by 分区排序

  • distribute by:

    • 类似MR中partition,采集hash算法,在map端将查询的结果中hash值相同的结果分发到对应的reduce文件中
    • 结合sort by使用。
  • 注意

    • Hive要求 distribute by 语句要写在 sort by 语句之前。
  • 案例实操

    • 先按照学生 sid 进行分区,再按照学生成绩进行排序

    • 设置reduce的个数

    set mapreduce.job.reduces=3;
    
    • 通过distribute by 进行数据的分区,,将不同的sid 划分到对应的reduce当中去
    insert overwrite local directory '/opt/install/hivedatas/distribute' select * from score distribute by s_id sort by s_score;
    

5.4.5 cluster by

  • 当distribute by和sort by字段相同时,可以使用cluster by方式代替

  • 除了distribute by 的功能外,还会对该字段进行排序,所以cluster by = distribute by + sort by

    --以下两种写法等价
    insert overwrite local directory '/opt/install/hivedatas/distribute_sort' select * from score distribute by s_score sort by s_score;
    
    insert overwrite local directory '/opt/install/hivedatas/cluster' select * from score  cluster by s_score;
    

6. 拓展点

  • 平时工作中,要多查看Hive官方文档

  • Hive可视化工具dbeaver

  • 总结

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

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

相关文章

4、监测数据采集物联网应用开发步骤(4)

监测数据采集物联网应用开发步骤(3) 日志或文本文件读写开发 创建全局变量配置代码com.zxy.common.Com_Para.py全局变量根据需要后续补充。 #! python3 # -*- coding: utf-8 -Created on 2023年08月28日 author: zxyong 13738196011#监测数据采集物联网应用--全局变量 impor…

文件名翻译不求人:一键批量翻译,你就是改名专家

文件名翻译不求人&#xff1a;一键批量翻译&#xff0c;你就是改名专家 在日常生活和工作中&#xff0c;我们常常需要处理各种文件&#xff0c;包括文档、图片、视频等。有时候&#xff0c;我们需要对这些文件进行重命名&#xff0c;以便更好地管理和查找。但是&#xff0c;当…

微服务之Nacos

1 版本说明 官网地址&#xff1a; https://github.com/alibaba/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E 1.1 2021.x 分支 适配 SpringBoot 2.4, Spring Cloud 2021.x 版本及以上的Spring Cloud Alibaba 版本如下表&#xff08;最新版本用*标记&am…

Android实现监听APP启动、前台和后台

Android 实时监听APP进入前台或后台 前言 在我们开发的过程中&#xff0c;经常会遇到需要我们判断app进入后台&#xff0c;或者切换到前台的情况。比如我们想判断app切换到前台时&#xff0c;显示一个解锁界面&#xff0c;要求用户输入解锁密码才能继续进行操作&#xff1b;我…

pdf怎么转换成jpg图片?这几个方法值得一试

pdf怎么转换成jpg图片&#xff1f;PDF格式的文件在我们的日常生活和工作中十分常见&#xff0c;但有时候我们需要将PDF文件转换成图片格式&#xff0c;以便于在网页上进行展示或者存放到手机相册中。那么&#xff0c;PDF怎么转换成JPG图片呢&#xff1f;下面介绍几种方法。 第一…

Java【手撕滑动窗口】LeetCode 209. “长度最小子数组“, 图文详解思路分析 + 代码

文章目录 前言一、长度最小子数组1, 题目2, 思路分析3, 代码 前言 各位读者好, 我是小陈, 这是我的个人主页, 希望我的专栏能够帮助到你: &#x1f4d5; JavaSE基础: 基础语法, 类和对象, 封装继承多态, 接口, 综合小练习图书管理系统等 &#x1f4d7; Java数据结构: 顺序表, 链…

达梦数据配置兼容

修改数据库实例的dm.ini配置文件COMPATIBLE_MODE的值&#xff0c;0:none, 1:SQL92, 2:Oracle, 3:MS SQL Server, 4:MySQL, 5:DM6, 6:Teradata, 7:PG COMPATIBLE_MODE 4 #Server compatible mode, 0:none, 1:SQL92, 2:Oracle, 3:MS SQL Server,…

如何设置让软件开机自启动

电脑重置&#xff0c;一些软件能正常使用&#xff0c;但是系统开机自启动选项中并没有它&#xff0c;这就很郁闷 有些极简软件没有直接设置开机自启&#xff0c;需要手动设置&#xff0c;所以我们就需要手动去设置一下它。 1、如果你在任务管理器里能找到它&#xff0c;也可以…

怎么把m4a转换成mp3?音频格式转换方法分享

M4A格式音频文件通常比MP3格式音频文件具有更高的音质&#xff0c;因为它使用了先进的编码技术。但是&#xff0c;M4A文件在某些设备上可能无法播放。将M4A文件转换为MP3格式可以增加音频文件的兼容性&#xff0c;并使其可以在更广泛的设备上播放&#xff0c;如移动设备和汽车音…

解决 git clone 时出现Failed to connect to 127.0.0.1 port 1573问题

今天去拉一个仓库代码&#xff0c;往常都是一下就拉下来了&#xff0c;今天却报错&#xff0c;报错信息如下&#xff1a; 原因&#xff1a;这种情况是因为代理在git中配置的&#xff0c;但是本身环境就有SSL协议了&#xff0c;所以取消git的https或者http代理即可 方法如下&…

文件夹无法删除?简单3招,轻松解决问题!

“我电脑里有一个文件夹占用了很大的内存&#xff0c;我想将它删除来释放一些内存&#xff0c;但是根本没法删除&#xff0c;为什么会这样呢&#xff1f;文件夹无法删除应该怎么办呢&#xff1f;” 在日常电脑使用中&#xff0c;有时候会遇到文件夹无法删除的情况&#xff0c;这…

iTween安装

1. 找到Package Manager面板&#xff0c;Packages选择MyAssets-右上角搜索iTween-找到后点DownLoad-点Import 导入 2. 导入后Assets面板结构如下图。 3. 编译器中输入iTween有提示&#xff0c;安装成功。

DataFrame.plot函数详解(六)

DataFrame.plot函数详解&#xff08;六&#xff09; 使用subplot()做子图&#xff0c;定位每一个子图&#xff0c;设置数据和图形&#xff0c;理解fig和ax(axs)的意义和作用。 1. subplot() matplotlib.pyplot.subplots(nrows1, ncols1, *, sharexFalse, shareyFalse, squee…

Spring Boot框架以及它的优势

文章目录 介绍1. **简化配置**2. **快速启动**3. **自动配置**4. **集成第三方库和框架**5. **微服务支持**6. **内嵌式数据库支持**7. **健康监控和管理**8. **可插拔的开发工具**9. **丰富的社区和生态系统**10. **良好的测试支持&#xff1a;** 核心特性**1. 依赖注入&#…

解决Python中的循环引用和内存泄漏问题

在Python编程中&#xff0c;循环引用和内存泄漏是两个常见的问题。本文将详细介绍如何识别和解决这些问题&#xff0c;并提供详细的代码示例。 1、什么是循环引用&#xff1f; 循环引用是指两个或多个对象之间相互引用的情况。这种情况可能导致内存泄漏&#xff0c;因为Python…

无涯教程-Android - 环境设置

您可以从Oracle的Java网站下载最新版本的Java JDK-Java SE下载&#xff0c;您将在下载的文件中找到有关安装JDK的说明,按照给定的说明安装和配置安装程序。最后,将PATH和JAVA_HOME环境变量设置为引用包含 java 和 javac 的目录,通常分别是java_install_dir/bin和java_install_d…

QML Book 学习基础3(动画)

目录 主要动画元素 例子&#xff1a; 非线性动画 分组动画 Qt 动画是一种在 Qt 框架下创建交互式和引人入胜的图形用户界面的方法&#xff0c;我们可以认为是对某个基础元素的多个设置 主要动画元素 PropertyAnimation-属性值变化时的动画 NumberA…

Sip分控管理主机 sip协议可视对讲话筒

Sip分控管理主机 sip协议可视对讲话筒 (型号:SV-3280) 产品特点 标准桌面主机&#xff0c;采用8寸高清IPS屏幕&#xff0c;屏幕分辨率1280*800&#xff0c;触摸控制设计&#xff0c;强化铝合金材质&#xff1b; 国产4核嵌入式CPU芯片1G内存&#xff0c;保证系统的整体稳定性&…

IPD集成产品开发进阶:新产品立项CDP流程

目录 前言 立项流程 专栏目录 CSDN学院 作者简介 前言 CDP 流程原本是 IPD 产品开发的前端流程。 之所以拿到《产品经理进阶专栏》中来讲解&#xff1a; 一是因为这个流程承接了市场管理&#xff08;也就是 MM 流程&#xff09;和产品开发这两个关键业务流。 这其实就…

《人生苦短,我学Python》——变量 常量 输入输出

今天&#xff0c;我们来学习变量&#xff0c;常量&#xff0c;以及字符串的输入输出。 文章目录 一、变量&#xff1a;二、常量&#xff1a;三、赋值&#xff1a;四、字符串的定义&#xff1a;五、格式化输出&#xff1a;六、转义字符&#xff1a;七、刷题练习&#xff1a;1. 小…