SQL进阶笔记

news2025/1/12 15:47:06

SQL进阶笔记

CASE表达式

  1. 简单case表达式

    case sex
    	when '1' then '男'
    	when '2' then '女'
    	else '其他' end
    
  2. 搜索case表达式

    case when sex ='1' then '男'
    	 when sex ='2' then '女'
    	 else '其他' end
    

    编写SQL语句的时候需要注意,在发现为真的WHEN子句时,CASE表达式的真假值判断就会中止,而剩余的WHEN子句会被忽略。为了避免引起不必要的混乱,使用WHEN子句时要注意条件的排他性

-- 这样写结果不会出现“第二”
case when col_1 in('a','b') then '第一'
	when col_1 in('a') then '第二'
	else '其他' end

注意事项:养成写ELSE子句的习惯(不要忘了写END、统一各分支返回的数据类型)

与END不同,ELSE子句是可选的,不写也不会出错。不写ELSE子句时,CASE表达式的执行结果是NULL。但是不写可能会造成“语法没有错误,结果却不对”这种不易追查原因的麻烦,所以最好明确地写上ELSE子句(即便是在结果可以为NULL的情况下)。养成这样的习惯后,我们从代码上就可以清楚地看到这种条件下会生成NULL,而且将来代码有修改时也能减少失误

3.简单例子1:统计下表PopTbl中的内容,得出如下表“统计结果”所示的结果

在这里插入图片描述

-- 把县编号转换成地区编号
select case pref_name
		when '德岛' then '四国'
		when '香川' then '四国'
		when '爱媛' then '四国'
		when '高知' then '四国'
		
		when '福冈' then '九州'
		when '佐贺' then '九州'
		when '长椅' then '九州'
		else '其他' end as district,
		sum(population)
		from poptbl
		group by
		case pref_name
		when '德岛' then '四国'
		when '香川' then '四国'
		when '爱媛' then '四国'
		when '高知' then '四国'
		
		when '福冈' then '九州'
		when '佐贺' then '九州'
		when '长椅' then '九州'
		else '其他' end
-- 在PostgreSQL和MySQL中可以这样写
select case pref_name
		when '德岛' then '四国'
		when '香川' then '四国'
		when '爱媛' then '四国'
		when '高知' then '四国'
		
		when '福冈' then '九州'
		when '佐贺' then '九州'
		when '长椅' then '九州'
		else '其他' end as district,
		sum(population)
		from poptbl
		group by district;
		/*
		这里的GROUP BY子句使用的正是SELECT子句里定义的列的别称——district。但是严格来说,这种写法是违反标准SQL的规则的。因为GROUP BY子句比SELECT语句先执行,所以在GROUP BY子句中引用在SELECT子句里定义的别称是不被允许的。事实上,在Oracle、DB2、SQL Server等数据库里采用这种写法时就会出错
		*/

4.简单例子2:

统计表poptbl2

在这里插入图片描述

结果表

  • 第一种做法,写两个查询,用union合并

    select pref_name,sum(population) from poptbl2 where sex ='1' group by pref_name;
    union
    select pref_name,sum(population) from poptbl2 where sex ='2' group by pref_name;
    
  • 第二种做法,使用case表达式

    select pref_name,
    -- 男性人口
    sum(case when sex ='1' then population else 0 end) as cnt_m,
    -- 女性人口
    sum(case when sex ='2' then polulation else 0 end) as cnt_f
    from poptbl2
    group by
    pref_name;
    /*
    上面这段代码所做的是,分别统计每个县的“男性”(即’1')人数和“女性”(即’2')人数。也就是说,这里是将“行结构”的数据转换成了“列结构”的数据。除了SUM, COUNT、AVG等聚合函数也都可以用于将行结构的数据转换成列结构的数据
    */
    

    5.用CHECK约束定义多个列的条件关系

    -- 假设某公司规定“女性员工的工资必须在20万日元以下”,而在这个公司的人事表中,这条无理的规定是使用CHECK约束来描述的,代码如下所示
    constraint check_salary check 
    (case when sex = '2' 
     then case when salary <=200000
    then 1 else 0 end
    else 1 end =1)
    -- 逻辑与也是一个逻辑表达式,意思是“P且Q”,记作P∧Q。用逻辑与改写的CHECK约束如下
    constraint check_salary check
    (sex = '2' and salary <=200000)
    /*
    说明:
    如果在CHECK约束里使用逻辑与,该公司将不能雇佣男性员工。而如果使用蕴含式,男性也可以在这里工作。
    解释:
    要想让逻辑与P∧Q为真,需要命题P和命题Q均为真,或者一个为真且另一个无法判定真假。也就是说,能在这家公司工作的是“性别为女且工资在20万日元以下”的员工,以及性别或者工资无法确定的员工(如果一个条件为假,那么即使另一个条件无法确定真假,也不能在这里工作)。而要想让蕴含式P→Q为真,需要命题P和命题Q均为真,或者P为假,或者P无法判定真假。也就是说如果不满足“是女性”这个前提条件,则无需考虑工资约束。*/
    
    

    6.逻辑与和蕴含式

在这里插入图片描述

蕴含式在员工性别不是女性(或者无法确定性别)的时候为真,可以说相比逻辑与约束更加宽松

简单应用:

假设现在需要根据以下条件对该表的数据进行更新。

1.对当前工资为30万日元以上的员工,降薪10%。

2.对当前工资为25万日元以上且不满28万日元的员工,加薪20%。按照这些要求更新完的数据应该如下表所示

在这里插入图片描述

执行下面两个UPDATE操作好像就可以做到,但这样的结果却是不正确的。

-- 对当前工资为30万日元以上的员工,降薪10%
update salarise set salary=salary*0.9 where salary >=300000;
-- 对当前工资为25万日元以上且不满28万日元的员工,加薪20%
update salarise set salary=salary*1.2 where salary >=250000 and salary <=280000;

分析一下不正确的原因:

例如这里有一个员工,当前工资是30万日元,按“条件1”执行UPDATE操作后,工资会被更新为27万日元,但继续按“条件2”执行UPDATE操作后,工资又会被更新为32.4万日元。这样,本来应该被降薪的员工却被加薪了2.4万日元

在这里插入图片描述

用case来写

update salarise set salary = case when salary >= 300000
                             	then salary*0.9
                             	then salary >= 250000 and
                             	salary <280000 
                             	then salary*1.2
                             	else salary end;
/* 
说明:
 需要注意的是,SQL语句最后一行的ELSE salary非常重要,必须写上。因为如果没有它,条件1和条件2都不满足的员工的工资就会被更新成NULL。这一点与CASE表达式的设计有关,在刚开始介绍CASE表达式的时候我们就已经了解到,如果CASE表达式里没有明确指定ELSE子句,执行结果会被默认地处理成ELSE NULL
 */

7.表之间的数据匹配

in和exisin和区别:

in 和 exists的区别: 如果子查询得出的结果集记录较少,主查询中的表较大且又有索引时应该用in, 反之如果外层的主查询记录较少,子查询中的表大,又有索引时使用exists。其实我们区分in和exists主要是造成了驱动顺序的改变(这是性能变化的关键),如果是exists,那么以外层表为驱动表,先被访问,如果是IN,那么先执行子查询,所以我们会以驱动表的快速返回为目标,那么就会考虑到索引及结果集的关系了 ,另外IN时不对NULL进行处理

练习1:

在这里插入图片描述

select key,case when x<y then y else x end as greatest from greatests;

练习2:

在这里插入图片描述

-- 用case表达式
select key,case when 
			case when x<y then y else x end <z 
			then z 
			else case when x<y then y else x end end as greatest
			from greatests;
-- 用max函数
select key,max(num) as greatest form(
			select key,x as num from greatsets
    		union all
    		select key,y as num from greatests
    		union all
    		select key,z as num from greatests
) as a
group by key;
-- Oracle或者MySQL数据库
select key,greatest(greatest(x,,y),z) as greatest from greatests;

练习3:

select sex,
-- 全国
sum(population) as numbers,
-- 德岛、香川、爱媛、高知
sum(case when pref_name ='德岛' then population eles 0 end as col_1 ),
sum(case when pref_name ='香川' then population else 0 end as col_2 ),
sum(case when pref_name ='爱媛' then population eles 0 end as col_3 ),
sum(case when pref_name ='高知' then population eles 0 end as col_4 ),
-- 四国
sum(case when pref_name in('德岛','香川','爱媛','高知') then population else 0 end as zaijie)
from poptbl2 
group by sex;

练习4:

在这里插入图片描述

select key from greatests 
order by 
case when b then 1 
	 when a then 2
	 when d then 3
	 when d then 4
	 else null end;						

自连接

  1. 删除重复行

在这里插入图片描述

  1. 查找局部不一致的列

    • 表Addresses

在这里插入图片描述

select distinct p1.name,p1.address from addresses p1,addresses p2  where p1.family_id=p2.family_id and p1.address<> p2.address; 
  • 表Products

在这里插入图片描述

select distinct p1.name,p1.price from products p1,products p2  where p1.name <> p2.name and p1.price = p2.price

三值逻辑和NULL

慨念

普通语言里的布尔型只有true和false两个值,这种逻辑体系被称为二值逻辑。而SQL语言里,除此之外还有第三个值unknown,因此这种逻辑体系被称为三值逻辑(three-valued logic)

两种NULL、三值逻辑还是四值逻辑

“两种NULL”这种说法大家可能会觉得很奇怪,因为SQL里只存在一种NULL。然而在讨论NULL时,我们一般都会将它分成两种类型来思考。因此这里先来介绍一些基础知识,即两种NULL之间的区别。

  • null的区别

    两种NULL分别指的是“未知”(unknown)和“不适用”(not applicable,inapplicable)。以“不知道戴墨镜的人眼睛是什么颜色”这种情况为例,这个人的眼睛肯定是有颜色的,但是如果他不摘掉眼镜,别人就不知道他的眼睛是什么颜色。这就叫作未知。而“不知道冰箱的眼睛是什么颜色”则属于“不适用”。因为冰箱根本就没有眼睛,所以“眼睛的颜色”这一属性并不适用于冰箱。

    总结:

    未知”指的是“虽然现在不知道,但加上某些条件后就可以知道”;而“不适用”指的是“无论怎么努力都无法知道”

  • 为什么必须写成“IS NULL”,而不是“=NULL”

    先看这个例子吧

    select * from table where name =null
    /*
    说明:
    对NULL使用比较谓词后得到的结果总是unknown。而查询结果只会包含WHERE子句里的判断结果为true的行,不会包含判断结果为false和unknown的行。不只是等号,对NULL使用其他比较谓词,结果也都是一样的。所以无论name是不是NULL,比较结果都是unknown
    */
    --类似还有
    1 = null
    2 > null
    3 < null
    4 <> null
    null = null
    

    null的理解:

    列的值为NULL”“NULL值”这样的说法本身就是错误的。因为NULL不是值,所以不在定义域(domain)中。相反,如果有人认为NULL是值,那么请问:它是什么类型的值?关系数据库中存在的值必然属于某种类型,比如字符型或数值型等。所以,假如NULL是值,那么它就必须属于某种类型

  • 比较谓词和NULL(1):排中律不成立

    我们假设约翰是一个人。那么,下面的语句(以下称为“命题”)是真是假?

    约翰是20岁,或者不是20岁,二者必居其一

    说明:是的这是正确的,但是现实世界中正确的事情在SQL里却不正确的情况时有发生。实际上约翰这个人是有年龄的,只是我们无法从这张表中知道而已。换句话说,关系模型并不是用于描述现实世界的模型,而是用于描述人类认知状态的核心(知识)的模型。因此,我们有限且不完备的知识也会直接反映在表里。

    表students

在这里插入图片描述

SQL查询语句

-- 查询约翰
select * from students where age = 20 or age <> =20 
-- 必须加了这个第三真值才会出现约翰
or age is null

比较谓词和NULL(2):CASE表达式和NULL

-- 错误写法
case col_1  when 1 then 'X'
		   when null then 'O' end
-- 说明:第二个句子相当于 col_1=null,所以结果显而易见
-- 正确写法
case when col_1 =1 then 'X' 
	when col_1 is null then 'O' end
  • NOT IN和NOT EXISTS不是等价的

在这里插入图片描述

EXISTS只会返回true或者false。因此就有了IN和EXISTS可以互相替换使用,而NOT IN和NOT EXISTS却不可以互相替换的混乱现象

总结:

1.NULL不是值。

2.因为NULL不是值,所以不能对其使用谓词。

3.对NULL使用谓词后的结果是unknown。

4.unknown参与到逻辑运算时,SQL的运行会和预想的不一样。

5.按步骤追踪SQL的执行过程能有效应对4中的情况。

要想解决NULL带来的各种问题,最佳方法应该是往表里添加NOT NULL约束来尽力排除NULL。这样就可以回到美妙的二值逻辑世界(虽然并不能完全回到)

HAVING子句的力量

简单例子:查找一个连续编号的表里是否存在缺失数据

表test_01

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-e14hHRom-1671262600579)(C:\Users\TiAmo\AppData\Roaming\Typora\typora-user-images\image-20220712100449328.png)]

-- 不存在就没有缺失数据,反之存在
select '存在缺失数据' as gpa from test_01 having count(*) <> max(id)
-- 查找缺失数据的最小值
select min(id+1) as id from test_01  where id+1 not in(select id from test_01)
  1. COUNT(*)和COUNT(列名)的区别

    第一个是性能上的区别;第二个是COUNT(*)可以用于NULL,而COUNT(列名)与其他聚合函数一样,要先排除掉NULL的行再进行统计

    第二个区别也可以这么理解:COUNT(*)查询的是所有行的数目,而COUNT(列名)查询的则不一定是。

在这里插入图片描述

-- 查询结果还是不一样
select count(*),count(number) from test_01

结果:

在这里插入图片描述

  1. 例子

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kw7oRWPR-1671262600580)(C:\Users\TiAmo\AppData\Roaming\Typora\typora-user-images\image-20220712103530795.png)]

    -- 可能会这样写
    select distinct shop from shopltems where item in(select item from items)
    -- 结果
    -- shop
    -- 仙台
    -- 东京
    -- 大版
    
    -- 正确的写法
    select t1.shop from shopltems t1,items t2 where t1.item=t2.item group byt1.item 
    -- 分组里数量一致
    having count(t1.item)=(select count(item) from items)
    

外连接(outer jion/left join)

简单例子:将下原表简化成结果表

原表:

DROP TABLE IF EXISTS `courses`;
CREATE TABLE `courses`  (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
  `course` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 9 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;
------------------------------------------------------------------------------------------------------
INSERT INTO `courses` VALUES (1, '赤井', 'SQL入门');
INSERT INTO `courses` VALUES (2, '赤井', 'UNIX基础');
INSERT INTO `courses` VALUES (3, '铃木', 'SQL入门');
INSERT INTO `courses` VALUES (4, '吉田', 'UNIX基础');
INSERT INTO `courses` VALUES (5, '工藤', 'SQL入门');
INSERT INTO `courses` VALUES (6, '渡边', 'SQL入门');
INSERT INTO `courses` VALUES (7, '工藤', 'Java中级');
INSERT INTO `courses` VALUES (8, '赤井', 'SQL入门');

在这里插入图片描述

结果表:

在这里插入图片描述

代码:

-- 第一种写法outer jion
SELECT
	t0.NAME,
CASE
		WHEN t1.NAME IS NOT NULL THEN
	'O' ELSE NULL 
	END AS 'SQL入门',
CASE
		WHEN t2.NAME IS NOT NULL THEN
	'O' ELSE NULL 
	END AS 'UNIX基础',
CASE
		WHEN t3.NAME IS NOT NULL THEN
	'O' ELSE NULL 
	END AS 'Java中级'
	from (select distinct `name` from courses) as t0
	left outer join 
	(select `name` from courses where course ='SQL入门') t1
	on t1.`name`=t0.`name`
	left outer join
	(select `name` from courses where course ='UNIX基础') t2
	on t2.`name`=t0.`name`
	left outer join
	(select `name` from courses where course ='Java中级') t3
	on t3.`name`=t0.`name`
	
	-- 第二种嵌套case表达式
	SELECT
	`name`,
	case when sum(case when course = 'SQL入门' then 1 ELSE null end)=1 then 'O' else null end as 'SQL入门',
	case when sum(case when course = 'UNIX基础' then 1 ELSE null end)=1 then 'O' else null end as 'UNIX基础',
	case when sum(case when course = 'Java中级' then 1 ELSE null end)=1 then 'O' else null end as 'Java中级'
	from
	courses
	GROUP BY 
	name;
-- 特别注意,错误的写法
SELECT
	t0.`name`,
	-- 这里会报 作为一个表达式使用的子查询返回了多列
-- 	( SELECT 'O' FROM courses t1 WHERE course = 'SQL入门' AND t0.`name` = t1.`name` ) AS 'SQL入门',
	( SELECT 'O' FROM courses t2 WHERE course = 'UNIX基础' AND t0.`name` = t2.`name` ) AS 'UNIX基础',
	( SELECT 'O' FROM courses t3 WHERE course = 'Java中级' AND t0.`name` = t3.`name`)  AS 'Java中级' 
FROM
	( SELECT DISTINCT `name` FROM courses ) as t0;

在这里插入图片描述

用关联子查询比较行与行

增长、减少、维持现状

例子:使用SQL输出与上一年相比营业额是增加了还是减少了

表:Sales

在这里插入图片描述

SQL:

-- 第一种写法,子查询
select t1.year,t1.sale,case 
-- 比较上一年的结果——>持平
when sale =(select sale from sales t2 where t2.year=t1.year-1 ) then '持平'
-- 上升
when sale >(select sale from sales t3 where t3.year=t1.year-1 ) then '上升'
-- 下降
when sale <(select sale from sales t3 where t3.year=t1.year-1 ) then '下降'
else '起点对比数据' end as sale_state
from sales t1
order by t1.year;

-- 第二种写法,自连接,会少一行1990
select t1.year,t1.sale,case
when t1.sale = t2.sale then '持平'
when t1.sale > t2.sale then '上升'
when t1.sale < t2.sale then '下降'
else '起点对比数据' end as sale_state
-- t2是上一年数据
from sales t1,sales t2
where t2.year=t1.year-1
order by t1.year

假如上表数据缺失就不能用year-1这个条件了

在这里插入图片描述

-- 查询每一年与过去最临近的年份之间的营业额之差
SELECT
	S2.YEAR AS pre_year,
	S1.YEAR AS now_year,
	S2.sale AS pre_sale,
	S1.sale AS now_sale,
	S1.sale - S2.sale AS diff 
	FROM Sales2 S1,Sales2 S2 
WHERE
	S2.YEAR = ( SELECT MAX( YEAR ) FROM Sales2 S3 WHERE S1.YEAR > S3.YEAR ) 
ORDER BY
	now_year;

查询重复的情况

酒店预约的简单例子:表——Reservations

在这里插入图片描述

SQL:

-- 查询日期冲突的客人
SELECT
	reserver,
	start_date,
	end_date 
FROM
	reservations t1 
WHERE
	EXISTS (
	SELECT
		* 
	FROM
		reservations t2 
	WHERE
        -- 和自己比较
		t1.reserver <> t2.reserver 
        -- 入住日期和离开日期 在别人住的时间
	AND ( t1.start_date BETWEEN t2.satrt_date AND t2.end_date OR t1.start_date BETWEEN t2.start_date AND t2.end_date ) 
	)

in和exists的区别

  1. 如果查询的两个表大小相当,那么用in和exists差别不大;如果两个表中一个较小一个较大,则子查询表大的用exists,子查询表小的用in
  2. EXISTS不仅可以将多行数据作为整体来表达高级的条件,而且使用关联子查询时性能仍然非常好

集合运算

UNION:交集

  1. 查询重复的数据
-- 公式 S UNION S = S
-- 查询A B表的数据
select count(*) as row_num from (select * from tableA union select * from tableB ) Tme

最近忙着做项目,还有一些后面再补充吧。

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

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

相关文章

Java并发编程(一)—— FutureTask超详细教程

一、前言 创建线程有几种方式?这个问题的答案应该是可以脱口而出的吧: 继承 Thread 类实现 Runnable 接口但这两种方式创建的线程是属于三无产品: 没有参数没有返回值没办法抛出异常用着三无产品总是有一些弊端,其中没办法拿到返回值是最让人不能忍的,于是 Callable 就诞…

TeamsApp LukcyDraw升级之路 之 DB Infra 篇

今天继续 LuckyDraw 的升级之路&#xff0c;之前在1500以上用户同时使用的时候&#xff0c;特别是在短时间内大家一起点击参与抽奖参的时候&#xff0c;服务会出现大量的错误&#xff0c;分析后发现&#xff0c;出现错误的原因基本都是 Azure Storage Table 返回的。当时使用 A…

【GRU回归预测】基于matlab卷积神经网络结合门控循环单元CNN-GRU数据预测(多输入单输出)【含Matlab期源码 2274期】

⛄一、CNN-GRU数据预测 1 理论基础 1.1 CNN算法 负荷序列数据为一维数据&#xff0c;用一维卷积核对数据进行卷积处理&#xff0c;以获取数据的特征。 现设定卷积核的维度为3&#xff0c;移动步长为1&#xff0c;对输入数据进行卷积&#xff0c;以获得特征图图谱&#xff0c;即…

记录那不用百度的美好代码

努力工作&#xff0c;日益消瘦&#xff0c;总有些代码不想记住。我称之为&#xff1a;拿来即用系列 一&#xff1a;格式化时间 1.去除时间的T // 去除日期中T function timeFormatSeconds(time) {if(!time) return time;var date time.substr(0, 10); //年月日var hours ti…

jsp+ssm计算机毕业设计宠物商城【附源码】

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; JSPSSM mybatis Maven等等组成&#xff0c;B/S模式 Mave…

基于SPRINGBOOT的健康饮食管理系统

11-8开发工具(eclipse/idea/vscode等)&#xff1a; 数据库(sqlite/mysql/sqlserver等)&#xff1a; 功能模块(请用文字描述&#xff0c;至少200字)&#xff1a; 基于springboot框架&#xff0c;通过对事物健康程度的总结与归纳&#xff0c;进行软件设计&#xff0c;并通过优秀的…

go 语言Http服务器远程执行shell命令

背景 想要在服务器上起一个http服务器&#xff0c;用来远程执行shell命令并且返回。 基础版 package mainimport ("io""log""net/http" )func main() {// Hello world, the web serverhelloHandler : func(w http.ResponseWriter, req *http.R…

性能脚本:用案例和图示帮你理解HTTP协议

当前使用得最为广泛的应用层协议就是 HTTP 了。我想了好久,还是觉得应该把 HTTP 协议写一下。 因为做性能测试分析的人来说,HTTP 协议可能是绕不过去的一个槛。在讲 HTTP 之前,我们得先知道一些基本的信息。 HTTP(HyperText Transfer Protocol,超文本传输协议),显然是…

linux shell编程

linux shell编程1.shell脚本概述2.脚本的调用形式3.shell脚本语法3.1 脚本开头标识3.2 脚本注释3.3 给脚本加上可执行权限3.4 shell脚本的运行方式3.5 检测脚本是否正确3.6 重定向的使用3.7 获取上一条命令的执行结果4.变量4.1 变量的定义和使用4.2 从键盘上读取变量&#xff1…

(十七)Vue之自定义指令

文章目录自定义指令局部指令回调函数形式配置对象形式全局配置回调函数形式配置对象形式Vue学习目录 上一篇&#xff1a;&#xff08;十六&#xff09;Vue之内置指令 先看两个需求&#xff1a; 需求1&#xff1a;定义一个v-big指令&#xff0c;和v-text功能类似&#xff0c;…

陈表达学VBA-msgbox辨别用户选择和代码调用

今天有个老客户提出需求&#xff1a; 模块&#xff1a;sub 过程A( ) ①如果是单独使用时则显示msgbox选择消息框 ②如果A过程调用B过程&#xff0c;则不显示消息框&#xff0c;默认选择是 msgbox没有设置默认值这个功能&#xff0c;msgbox也没有参数可以失败是用户点击还是代…

pytorch基础操作(六)利用L2范数(权重衰减)解决线性模型过拟合问题

一、一些概念 训练误差&#xff08;training error&#xff09; 是指&#xff0c;模型在训练数据集上计算得到的误差。 泛化误差&#xff08;generalization error&#xff09; 是指&#xff0c;模型应⽤在同样从原始样本的分布中抽取的⽆限多数据样本时&#xff0c;模型误差的…

【Linux】Linux基本指令

Linux基本指令1.ls指令2.pwd指令3.cd指令3.touch 指令4.mkdir指令5. rmdir指令 && rm 指令5.1 rmdir5.2 rm6.tree 指令7.man指令8.cp指令9.mv指令10. cat指令11.echo指令12.more指令13.less指令14.wc指令15.head指令16.tail指令17. | &#xff08;管道指令&#xff09;…

每天五分钟机器学习:PCA算法如何确定数据压缩降维的最佳维度?

本文重点 上节课程中我们已经学习了pca算法,已经知道了如何将n维特征变量降到k维,k是PCA算法的一个参数,也被称为主成分的数量。那么现在就产生了一个问题,这个问题就是如何选择K,因为PCA要做的就是要尽量减少投射的平均均方误差,所以K的选择很关键。 平均均方误差 其中…

22.MongoDB删除操作效率及相关问题验证

最近遇到一个了一个MongoDB数据删除的问题&#xff0c;需要一次性删除上线即1.5年前~1年前的数据且之后每天清空一年过期的数据。在数据量比较大的情况下何种方式的删除效率最高是一个值得研究的问题&#xff0c;本文通过实际测试找出其中规律。 本文采用腾讯云mongodb集群进行…

基于java的连连看游戏设计-计算机毕业设计

项目介绍 基于java设计的连连看游戏规则是模仿网络上的最普通的连连看游戏&#xff0c;主要是鼠标点击两次的图片能否消去的问题。当前&#xff0c;前提是点击两张相同的图片&#xff0c;若是点击的是同一张图片或者两张不同的图片&#xff0c;则不予处理。在两张相同的图片所…

这份pdf成功让我拿下了蚂蚁金服、字节跳动、小米等大厂的offer

关于程序员&#xff0c;除了做项目来提高自身的技术之外&#xff0c;还有一种提升自己的专业技能就是&#xff1a;多&#xff01;看&#xff01;书&#xff01; 小编整理出一篇Java进阶架构师之路的核心知识&#xff0c;同时也是面试时面试官必问的知识点&#xff0c;篇章也是…

点云可视化工具

点云可视化工具 平时查看点云文件主要是用CloudCompare&#xff0c;基本上也就是打开看看这个点云大概是个什么样子&#xff0c;很少会在CloudCompare对点云进行处理&#xff0c;它可以直接将点云拖进软件进行显示也还是挺方便的。但是还是有点点不是很方便的地方&#xff0c;…

Linux从入门到进阶学习(Ⅲ):Linux权限管控

目录 1 root用户 1.1 su 1.2 sudo 2 用户和用户组 3 查看权限控制信息 4 修改权限控制 4.1 chmod命令 4.2 chown命令 1 root用户 1.1 su root用户即超级管理员 su [-] [用户名] 切换到root用户&#xff0c;exit退回普通用户从 -&#xff1a;可选&#xff0…

社会网络分析工具—— Gephi 或 NetworkX的简单介绍和比较(源自GPTchat)

文章目录我的原始需求两个工具介绍二者比较下载和使用后续 使用教程我的原始需求 如何对不同认知课堂的教师提问行为序列进 行社会网络分析&#xff0c;计算不同认知层级提问行为的中间 中心度和接近中心度&#xff0c; 在进行社会网络分析时&#xff0c;您首先需要收集数据并…