Shell中的$0、$1、$2的含义 $0 就是你写的shell脚本本身的名字 $1 是你给你写的shell脚本传的第一个参数 $2 是你给你写的shell脚本传的第二个参数 例子 脚本 #!.../bin/bash echo $0 # 打印脚本文件名 case $1 in # start) echo $1 ;; # 第一个参数是start,打印第一个参数 stop) echo...$1 ;; # 第一个参数是start,打印第一个参数 *) echo "require start|stop" ;; # 第一个参数既不是start也不是stop esac echo $2
正确地创建和使用索引是实现高性能查询的基础,本文笔者介绍MySQL中的前缀索引和多列索引。...不要对索引列进行计算 如果我们对索引列进行了计算,那么索引会失效,例如 explain select * from account_batch where id + 1 = 19298 复制代码 就会进行全表扫描...,因为MySQL无法解析id + 1 = 19298这个方程式进行等价转换,另外使用索引时还需注意字段类型的问题,如果字段类型不一致,同样需要进行索引列的计算,导致索引失效,例如 explain select...对于BLOB和TEXT类型,MySQL必须使用前缀索引,具体使用多少个字符建立前缀,需要对其索引选择性进行计算。...); Using where 复制代码 如果是在AND操作中,说明有必要建立多列联合索引,如果是OR操作,会耗费大量CPU和内存资源在缓存、排序与合并上。
一.变量总结 1. $$ Shell本身的PID(ProcessID) 2. $! Shell最后运行的后台Process的PID 3. $? ...如"$*"用「"」括起来的情况、以"$1 $2 … $n"的形式输出所有参数。 6. $@ 所有参数列表。...如"$@"用「"」括起来的情况、以"$1" "$2" … "$n" 的形式输出所有参数。 .... $# 添加到Shell的参数个数 8. $0 Shell本身的文件名 9.$1~$n 添加到Shell的各参数值。$1是第1参数、$2是第2参数…。 .../bin/bash echo "number:$#" echo "scname:$0" echo "first :$1" echo "second:$2" echo "argume:$@"
我们先来写一个简单的脚本,执行以后再看各个变量的意义。 [root@centos7 ~]#vim r1.sh #!...如"$*"用「"」括起来的情况、以"$1 $2 … $n"的形式输出所有参数。 printf "The complete list is %s\n" "$@" //所有参数列表。...如"$@"用「"」括起来的情况、以"$1" "$2" … "$n" 的形式输出所有参数。...$1是第1参数、$2是第2参数…。 printf "The complete list is %s\n" "$2" //添加到Shell的各参数值。$1是第1参数、$2是第2参数…。.../r1.sh 123456 QQ The complete list is 5327 The complete list is The complete list is 0 The complete
数据标准化,是将数据按比例缩放,使之落入到特定区间,一般我们使用0-1标准化; x=(x-min)/(max-min) >data 1.csv', fileEncoding='...utf-8') > data class name score 1 一班 朱志斌 120 2 一班 朱凤 122 3 一班 郑丽萍 140 4 一班 郭杰明...1标准化的区别。...标准化的方法很多,根据实际数据分析需求进行选择。...> scale<-scale(data$score) > scale [,1] [1,] -0.0865256 [2,] 0.0741648 [3,]
exit 0:正常运行程序并退出程序; exit 1:非正常运行导致退出程序; exit 0 可以告知你的程序的使用者:你的程序是正常结束的。...如果 exit 非 0 值,那么你的程序的使用者通常会认为 你的程序产生了一个错误。 在 shell 中调用完你的程序之后,用 echo $? 命令就可以看到你的程序的 exit 值。...在 shell 脚本中,通常会根据 上一个命令的 $? 值来进行一些流程控制。 当你 exit 0 的时候,在调用环境 echo $?...就返回0,也就是说调用环境就认为你的这个程序执行正确 当你 exit 1 的时候,一般是出错定义这个1,也可以是其他数字,很多系统程序这个错误编号是有约定的含义的。...如果你用 脚本 a 调用 脚本b ,要在a中判断b是否正常返回,就是根据 exit 0 or 1 来识别。 执行完b后, 判断 $?
《MySQL的隐式转换导致诡异现象的案例一则》文章中原始有段写的是, 上述例子中 "测试a" 会截成 "",因此 a=0 ,才会返回字段不为空的。 有朋友留言说,这个确定正确吗?"...因为数据类型的问题,"测试a"会转成数值类型,MySQL自动截断,应该截成的是""(空),只是说""和0是相等的,通过CAST可以验证下,"测试a"和''(空)转换成数值类型都是0, select cast...('测试a' AS UNSIGNED), CAST('' AS UNSIGNED); 如果准确些,应该说的是"测试a"自动截成""(空),""和0是相等的,因此得到"a=0"。...《最近碰到的一些问题》 《MySQL客户端指令用法的探索》 近期的热文: 《推荐一篇Oracle RAC Cache Fusion的经典论文》 《"红警"游戏开源代码带给我们的震撼》 文章分类和索引...: 《公众号1200篇文章分类和索引》
switch开关经常用在是否启用的场合,但是switch默认绑定值的类型是布尔类型,即true和false,在实际的项目中,后端的接口都会用0和1来代替,如何将数值与状态进行关联呢?...我们可以用active-value绑定要启用状态的值,用inactive-value绑定禁用状态的值,这两个值默认对应的是字符串类型。..." active-color="#13ce66" inactive-color="#cccccc" active-value="1"...inactive-value="0" @change="changeStatus(obj.row.id)" > </el-switch...active-color="#13ce66" inactive-color="#cccccc" :active-value="1"
2022-01-08:数组中只有0和1,每过1代,0旁边只有1个1,当前0会变成1。每过1代,0旁边有2个1,当前0还是0。 比如10001,经过1代,会变成11011,再过1代,还是11011 。...求一个数组经过M代以后的数组。函数定义是void f(int[] arr,int m) 。 答案2022-01-08: x里有有限个0。 1x1,中间0,x中有2m个0变成1,最中间的0不会变成1。...f(arr, 2) fmt.Println(arr) } func f(arr []byte, m int) { //找中间0 oneIndexList := make([]int...if len(oneIndexList) == 2 { for j := oneIndexList[0] + 1; j 1]-1; j++ {...: [图片] *** 题目来自左神,代码是自己写的。
多列族引起的问题和设计 HBase集群的每个region server会负责多个region,每个region又包含多个store,每个store包含Memstore和StoreFile。...HBase表中,每个列族对应region中的一个store。默认情况下,只有一个region,当满足一定条件,region会进行分裂。...如果一个HBase表中设置过多的列族,则可能引起以下问题: 一个region中存有多个store,当region分裂时导致多个列族数据存在于多个region中,查询某一列族数据会涉及多个region导致查询效率低...(这一点在多个列族存储的数据不均匀时尤为明显) 多个列族则对应有多个store,那么Memstore也会很多,因为Memstore存于内存,会导致内存的消耗过大 HBase中的压缩和缓存flush是基于...region的,当一个列族出现压缩或缓存刷新时会引起其他列族做同样的操作,列族过多时会涉及大量的IO开销 所以,我们在设计HBase表的列族时,遵循以下几个主要原则,以减少文件的IO、寻址时间: 列族数量
系统:Windows 10 编辑器:JetBrains PyCharm Community Edition 2018.2.2 x64 pandas:1.1.5 这个系列讲讲Python的科学计算及可视化...今天讲讲pandas模块 抽取Df中两列构成一个字典 Part 1:场景描述 已知df1,包括6列,"time", "pos", "value1", "value2", "value3", "value4...抽取其中的pos和value1列构成一个字典 由df生成字典 Part 2:代码 import pandas as pd dict_1 = {"time": ["2019-11-02", "...(list(step_1)) print(list(step_1)[0]) step_2 = step_1['value1'] print("\n步骤2") print(step_2) print(type...(step_2)) print(list(step_2)) print(list(step_2)[0]) step_3 = step_2.apply(list) print("\n步骤4") print
而在SQL面试中,一道出镜频率很高的题目就是行转列和列转行的问题,可以说这也是一道经典的SQL题目,本文就这一问题做以介绍分享。 ? 给定如下模拟数据集,这也是SQL领域经典的学生成绩表问题。...两张期望的数据表分别如下: 1)长表: ? scoreLong 2)宽表: ?...其基本的思路是这样的: 在长表的数据组织结构中,同一uid对应了多行,即每门课程一条记录,对应一组分数,而在宽表中需要将其变成同一uid下仅对应一行 在长表中,仅有一列记录了课程成绩,但在宽表中则每门课作为一列记录成绩...由多行变一行,那么直觉想到的就是要groupby聚合;由一列变多列,那么就涉及到衍生提取; 既然要用groupby聚合,那么就涉及到将多门课的成绩汇总,但现在需要的不是所有成绩汇总,而仍然是各门课的独立成绩...02 列转行:union 列转行是上述过程的逆过程,所以其思路也比较直观: 行记录由一行变为多行,列字段由多列变为单列; 一行变多行需要复制,列字段由多列变单列相当于是堆积的过程,其实也可以看做是复制;
标签:VBA 自Excel 2010发布以来,已经具备删除工作表中重复行的功能,如下图1所示,即功能区“数据”选项卡“数据工具——删除重复值”。...图1 使用VBA,可以自动执行这样的操作,删除工作表所有数据列中的重复行,或者指定列的重复行。 下面的Excel VBA代码,用于删除特定工作表所有列中的所有重复行。....CurrentRegion ReDim Cols(0 To rng.Columns.Count - 1) For i = 0 To UBound(Cols) Cols(...如果只想删除指定列(例如第1、2、3列)中的重复项,那么可以使用下面的代码: Sub DeDupeColSpecific() Cells.RemoveDuplicates Columns:=Array...(1, 2, 3), Header:=xlYes End Sub 可以修改代码中代表列的数字,以删除你想要的列中的重复行。
行转列,列转行是我们在开发过程中经常碰到的问题。行转列一般通过CASE WHEN 语句来实现,也可以通过 SQL SERVER 的运算符PIVOT来实现。用传统的方法,比较好理解。...但是PIVOT 、UNPIVOT提供的语法比一系列复杂的SELECT…CASE 语句中所指定的语法更简单、更具可读性。下面我们通过几个简单的例子来介绍一下列转行、行转列问题。...实际中,可能支付方式特别多,而且逻辑也复杂很多,可能涉及汇率、手续费等等(曾经做个这样一个),如果支付方式特别多,我们的CASE WHEN 会弄出一大堆,确实比较恼火,而且新增一种支付方式,我们还得修改脚本如果把上面的脚本用动态...这个是因为:对升级到 SQL Server 2005 或更高版本的数据库使用 PIVOT 和 UNPIVOT 时,必须将数据库的兼容级别设置为 90 或更高。...下面我们来看看列转行,主要是通过UNION ALL ,MAX来实现。
STM32中的BOOT0和BOOT1是用来设置启动方式的。 所谓启动,一般来说就是指我们下好程序后,重启芯片时,SYSCLK的第4个上升沿,BOOT引脚的值将被锁存。...用户可以通过设置BOOT1和BOOT0引脚的状态,来选择在复位后的启动模式。...Step2:最后在BootLoader的帮助下,通过串口下载程序到Flash中。...Step3:程序下载完成后,又有需要将BOOT0设置为GND,手动复位,这样,STM32才可以从Flash中启动。 当BOOT0和BOOT1均设置为逻辑1时,系统将从内置SRAM中启动。...主存储块用于保存具体的程序代码和用户数据;信息块用于负责由STM32出厂时放置2KB的启动程序(Bootloader)和 512B的用户配置信息区。
一、标准输入,标准输出,标准错误 bash中0,1,2三个数字分别代表STDIN_FILENO、STDOUT_FILENO、STDERR_FILENO,即标准输入(一般是键盘),标准输出(一般是显示屏,...有时候会看到如 ls >> 1.txt这类的写法,> 和 >> 的区别在于:> 用于新建而>>用于追加。...三、输出到一个终端 默认输入只有一个(0,STDIN_FILENO),而默认输出有两个(标准输出1 STDOUT_FILENO,标准错误2 STDERR_FILENO)。...因此默认情况下,shell输出的错误信息会被输出到2,而普通输出信息会输出到1。但是某些情况下,我们希望在一个终端下看到所有的信息(包括标准输出信息和错误信息),要怎么办呢?...即1在此处不被解释为STDOUT_FILENO,而是文件1。 五、结论 到了此时,你应该也能猜到2>&1的用意了。不错,2>&1就是用来将标准错误2重定向到标准输出1中的。
使用DAX在数据表中新建计算列,经常从另一个表中查找返回符合条件的值,类似于Excel的VLOOKUP,又高于Excel的VLOOKUP。...举例以销量表和价格表为例,为销量表从价格表中查找返回产品的价格。基于查找表(价格表)的3种形式,对应有3种方案。...方案1 两表之间存在一对一或多对一关系,用RELATED函数,与Excel的VLOOKUP最相似。...1 方向是多端查找一端2 支持跨表的关系传递3 性能优于其他方案4 非活动的虚线关系不适用价格表中每个产品只出现一次,每个产品只对应一个价格,存在多对一关系。...1 返回的值必须唯一,否则返回空或者预设结果(公式的最后一个参数)2 支持多条件查找价格表中产品的价格需要靠产品列和年份锁定唯一值。
A Linux中0、1、2的含义 名称 代码 操作符 Java中表示 Linux 下文件描述符(Debian 为例) 标准输入(stdin) 0 /proc/self/fd/0 -> /dev/pts/0 标准输出(stdout) 1 >, >>, 1> 或 1>> System.out /dev/stdout -> /proc/self/...fd/1 -> /dev/pts/0 标准错误输出(stderr) 2 2> 或 2>> System.err /dev/stderr -> /proc/self/fd/2 -> /dev/pts/0...从上面可以得到, 平时写的echo "hello" > t.log 也可以写成echo "hello" 1> t.log B 关于2>&1的含义 含义:将标准错误输出重定向到标准输出 符号>&是一个整体...回答: 我们不妨把1和2都理解是一个指针,那么这么想 本来1->屏幕(1指向屏幕) 执行>log后,1->log(1指向log) 执行2>&1后,2->1(2指向1,而1指向log,因此2也指向了
本文处理的场景如下,hive表中的数据,对其中的多列进行判重deduplicate。...1、先解决依赖,spark相关的所有包,pom.xml spark-hive是我们进行hive表spark处理的关键。...(s, 1); } }).reduceByKey(new Function2() {..._2 > 1) { retMap.put(stringIntegerTuple2._1, stringIntegerTuple2._2);.../bin/bash source /etc/profile source ~/.bash_profile db=$1 table=$2 partition=$3 cols=$4 spark-submit
die(‘1’) die()和exit()都是中止脚本执行函数;其实exit和die这两个名字指向的是同一个函数,die()是exit()函数的别名。...该函数只接受一个参数,可以是一个程序返回的数值或是一个字符串,也可以不输入参数,结果没有返回值。 参考:虽然两者相同,但通常使用中也有细微的选择性。...当传递给exit和die函数的值为0时,意味着提前终止脚本的执行,通常用exit()这个名字。.../readme.txt","r") or die("不能打开该文件"); //这种情况下,如果fopen函数被调用返回布尔值false时,die()将立即终止脚本,并马上打印 //传递给它的字符串,“死前还能说一两句话...exit(‘0’) 输出0 并结束程序 echo "begin"; exit('0'); echo "end"; //输出begin0 exit(‘1’) 输出1 并结束程序 echo "begin"
领取专属 10元无门槛券
手把手带您无忧上云