对于SQL的Join,在学习起来可能是比较乱的。我们知道,SQL的Join语法有很多inner的,有outer的,有left的,有时候,对于Select出来的结果集是什么样子有点不是很清楚。Coding Horror上有一篇文章,通过文氏图 Venn diagrams 解释了SQL的Join。我觉得清楚易懂,转过来。 交差集" cross join 《Linux命令行与shell脚本编程大全

对于SQL的Join,在学习起来可能是比较乱的。我们知道,SQL的Join语法有很多inner的,有outer的,有left的,有时候,对于Select出来的结果集是什么样子有点不是很清楚。Coding Horror上有一篇文章,通过文氏图 Venn diagrams 解释了SQL的Join。我觉得清楚易懂,转过来。

 

 对于SQL的Join,在学习起来可能是比较乱的。我们知道,SQL的Join语法有很多inner的,有outer的,有left的,有时候,对于Select出来的结果集是什么样子有点不是很清楚。Coding Horror上有一篇文章,通过文氏图 Venn diagrams 解释了SQL的Join。我觉得清楚易懂,转过来。

    假设我们有两张表。Table A 是左边的表。Table B 是右边的表。其各有四条记录,其中有两条记录name是相同的,如下所示:让我们看看不同JOIN的不同。

A表

  

id

name

1

Pirate

2

Monkey

3

Ninja

4

Spaghetti

     

B表

  

id

name

1

Rutabaga

2

Pirate

3

Darth Vade

4

Ninja

   

   

1.  INNER JOIN

SELECT * FROM TableA INNER JOIN TableB ON TableA.name = TableB.name

结果集

  

  

  

(TableA.)

  

(TableB.)

  

id

name

id

name

1

Pirate

2

Pirate

3

Ninja

4

Ninja

             

   

    Inner join 产生的结果集中,是A和B的交集。

2. FULL [OUTER] JOIN 

(1)

SELECT * FROM TableA FULL OUTER JOIN TableB ON TableA.name = TableB.name 

结果集

  

  

  

(TableA.)

  

(TableB.)

  

id

name

id

name

1

Pirate

2

Pirate

2

Monkey

null

null

3

Ninja

4

Ninja

4

Spaghetti

null

null

null

null

1

Rutabaga

null

null

3

Darth Vade

            

   

Full outer join 产生A和B的并集。但是需要注意的是,对于没有匹配的记录,则会以null做为值。

可以使用IFNULL判断。

(2)

SELECT * FROM TableA FULL OUTER JOIN TableB ON TableA.name = TableB.name

WHERE TableA.id IS null OR TableB.id IS null

结果集

  

  

  

(TableA.)

  

(TableB.)

  

id

name

id

name

2

Monkey

null

null

4

Spaghetti

null

null

null

null

1

Rutabaga

null

null

3

Darth Vade

        

   

 产生A表和B表没有交集的数据集。

   

3. LEFT [OUTER] JOIN

(1)  SELECT * FROM TableA LEFT OUTER JOIN TableB ON TableA.name = TableB.name

结果集

  

  

  

(TableA.)

  

(TableB.)

  

id

name

id

name

1

Pirate

2

Pirate

2

Monkey

null

null

3

Ninja

4

Ninja

4

Spaghetti

null

null

               

   

   Left outer join 产生表A的完全集,而B表中匹配的则有值,没有匹配的则以null值取代。

(2)

SELECT * FROM TableA LEFT OUTER JOIN TableB ON TableA.name = TableB.name WHERE TableB.id IS null

结果集

  

  

  

(TableA.)

  

(TableB.)

  

id

name

id

name

2

Monkey

null

null

4

Spaghetti

null

null

           

   

    产生在A表中有而在B表中没有的集合。

4. RIGHT [OUTER] JOIN

RIGHT OUTER JOIN 是后面的表为基础,与LEFT OUTER JOIN用法类似。这里不介绍了。

5. UNION 与 UNION ALL

UNION 操作符用于合并两个或多个 SELECT 语句的结果集。

请注意,UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同。UNION 只选取记录,而UNION ALL会列出所有记录。

(1) SELECT name FROM TableA UNION SELECT name FROM TableB

新结果集

name

Pirate

Monkey

Ninja

Spaghetti

Rutabaga

Darth Vade

选取不同值

(2) SELECT name FROM TableA UNION ALL SELECT name FROM TableB

新结果集

name

Pirate

Monkey

Ninja

Spaghetti

Rutabaga

Pirate

Darth Vade

Ninja  

全部列出来

(3) 注意:

SELECT * FROM TableA UNION SELECT * FROM TableB

新结果集

  

id

name

1

Pirate

2

Monkey

3

Ninja

4

Spaghetti

1

Rutabaga

2

Pirate

3

Darth Vade

4

Ninja

由于 id 1 Pirate   与 id 2 Pirate 并不相同,不合并

   

     还需要注册的是我们还有一个是"交差集" cross join, 这种Join没有办法用文式图表示,因为其就是把表A和表B的数据进行一个N*M的组合,即笛卡尔积。表达式如下:

     SELECT * FROM TableA CROSS JOIN TableB

     这个笛卡尔乘积会产生 4 x 4 = 16 条记录,一般来说,我们很少用到这个语法。但是我们得小心,如果不是使用嵌套的select语句,一般系统都会产生笛卡尔乘积然再做过滤。这是对于性能来说是非常危险的,尤其是表很大的时候。

 

还需要注册的是我们还有一个是“交差集” cross join, 这种Join没有办法用文式图表示,因为其就是把表A和表B的数据进行一个N*M的组合,即笛卡尔积。表达式如下:

 

   

     还需要注册的是我们还有一个是"交差集" cross join, 这种Join没有办法用文式图表示,因为其就是把表A和表B的数据进行一个N*M的组合,即笛卡尔积。表达式如下:

     SELECT * FROM TableA CROSS JOIN TableB

     这个笛卡尔乘积会产生 4 x 4 = 16 条记录,一般来说,我们很少用到这个语法。但是我们得小心,如果不是使用嵌套的select语句,一般系统都会产生笛卡尔乘积然再做过滤。这是对于性能来说是非常危险的,尤其是表很大的时候。

 

《Linux命令行与shell脚本编程大全》 第三章 学习笔记

 

第三章:基本的bash shell命令

 

bash程序使用命令行参数来修改所启动shell的类型

参数 描述
-c string 从string中读取命令并处理他们
-r 启动限制性shell,限制用户在默认目录下活动
-i 启动交互性shell,允许用户输入
-s 从标准输入读取命令

 

环境变量PS1、PS2

PS1:控制默认命令行提示符格式

PS2:控制后续命令行提示符格式

 

bash shell提示符字符串中使用的特殊字符

字符 描述
\a 报警字符
\d “日 月 年”格式显示的日期
\e ASCII转义字符
\h 本地主机名
\H 完全限定名(FQDN)
\j shell当前管理的任务数
\l shell的终端设备名中的基名
\n ASCII换行符
\r ASCII回车符
\s shell的名称
\t 24小时制HH:MM:SS格式的当前时间
\T 12小时制HH:MM:SS格式的当前时间
\@ 12小时制am/pm格式的当前时间
\u 当前用户的用户名
\v bash shell的版本
\V bash shell的发行版本
\w 当前工作目录
\W 当前工作目录的基名
\! 这个命令在bash shell历史记录中的位置
\# 这个命令在当前命令行的位置
\$ 普通用户下的美元符,root用户下的井号
\nnn 与8进制nnn对应的字符
\\ 反斜线
\[ 开始一个控制字符序列
\] 结束一个控制字符序列

 

Linux文件系统

Linux PC上安装的第一块硬盘为根驱动器。根驱动器包含了虚拟目录的核心,其他目录都是从那里开始创建的

挂载点(mount point)是虚拟目录中用于分配额外存储设备的目录

 

ls

(其余参数及例子见#2 )

单字母 全字 描述
-A --almost-all 不要输出“.”和“..”文件
  --author 作者
-b --escape 输出不可打印字符的8进制值
  --block-size=size 按size字节大小的块来计算块大小(块数)
-B --ignore-backups 不要列出名称中包含波浪线(~)的条目(波浪线用来表示备份的副本)
-F --classify 给条目追加文件类型标识符
  --file-type 只在部分文件类型(非可执行文件)后追加文件类型标识符
  --format=word 将输出格式化成across(交叉)、commas(逗号)、horizontal(水平)、long(长)、single-column(单列)、verbose(详细)或vertical(垂直)
  --group-directories-first 在文件之前列出所有目录
-G --no-group 长列表输出格式下,不要显示组名(in a long listing, don't print group names)
-h --human-readable 打印大小
  --si 和-h相同,但进制为1000
-i --inode 显示每个文件的索引值(inode)(见#1 )
-L --dereference 对于链接文件,显示原文件信息
-n --numeric-uid-gid 显示数字类型的userid和groupid以替代名字
-o   长列表输出格式下,不要显示组信息(like -l, but do not list group information)
-S --sort=size 按文件大小排序输出
-U --sort=none 不要将输出排序
-v --sort=version 按文本版本排序
-x   按行而非列输出条目
-X --sort=extension 按文件扩展名排序输出

 

 

创建文件(touch) (见#1 )

复制文件(cp) (见#1 )

cp命令参数

参数 描述
-a 归档文件,并保留他们现有的属性
-b 创建已存在目标文件的备份,而非覆盖它
-d 保留
-f 强制覆盖已存在的目标文件,不提示
-i 在覆盖目标文件之前提示
-l 创建文件链接而非复制文件
-p 如果可能,保留文件属性
-r 递归复制文件
-R 递归复制目录
-s 创建一个符号链接而非复制文件
-S 覆盖默认的备份文件的后缀(默认为~)
-u 仅在源文件比目标文件新的情况下复制
-v 详细模式,解释到底发生了什么
-x 仅限于当前文件系统的复制

(见#1 )

 

链接文件 (见#1 )

硬链接会创建一个独立的文件,其中包含源文件的信息以及位置。引用硬链接文件等同于引用了源文件

只能在同种存储媒体上的文件之间建立硬链接。不能在不同挂载点下的文件之间创建硬链接,但是可以创建软链接

 

如果用cp复制一个链接到另一个源文件的文件,那么复制的是源文件的另一个副本,而不是链接文件

可以创建一个指向源文件的新链接,而不用复制链接文件

可以创建指向同一文件的多个链接,但不要创建指向其他符号链接文件的多个符号链接(这样会生成一个链接文件链,容易混淆、断掉)

 

重命名文件(mv) (见#1 ,#2 )

删除文件(rm) (见#1 )

当删除所有此文件的硬链接时,此文件才会被删除

删除软链接指向的文件后,软链接指向无效的文件

  

创建目录(mkdir) (见#2 )

删除目录(rmdir) (见#2 )

查看文件统计信息(stat) (见#1 )

查看文件类型(file) (见#2 )

查看整个文件(cat、more、less) (见#16 ,#21 )

cat -T:制表符用^I代替

 

more

语法

more  [-s ] [file ...]

-s(squeeze,挤压) :将多个空白行压缩成一个

基本命令
h 显示帮助信息
<Space>、z 前进一屏
q 退出程序
高级命令
= 显示当前行号
<Return>、s 前进一行
d 前进(向下)半屏
f 前进一屏
b 后退一屏
/pattern 向前搜索指定模式
/ 重复上次搜索
!command 执行指定的shell命令
v 使用当前文件启动vi编辑器
. 重复执行前一个命令
n 在文件中查找下溢出匹配已指定表达式的内容
' 跳到指定表达式匹配到的第一处内容
CTRL+L 重绘当前屏

 

查看部分文件(head、tail) (见#16 )

posted @ 2018-05-27 22:58  ~雨落忧伤~  阅读(91)  评论(0编辑  收藏  举报