数据库中union的用法

数据库中union的用法,第1张

数据库中union的用法的用法你知道吗?下面我就跟你们详细介绍下数据库中union的用法的用法,希望对你们有用。

数据库中union的用法的用法如下:

UNION 指令的目的是将两个 SQL 语句的结果合并起来。从这个角度来看, UNION 跟 JOIN 有些许类似,因为这两个指令都可以由多个表格中撷取资料。 UNION 的一个限制是两个 SQL 语句所产生的栏位需要是同样的资料种类。另外,当我们用 UNION这个指令时,我们只会看到不同的资料值 (类似 SELECT DISTINCT)。 union只是将两个结果联结起来一起显示,并不是联结两个表………… UNION 的语法如下: [SQL 语句 1]

UNION

[SQL 语句 2] 假设我们有以下的两个表格,

Store_Information 表格

store_name Sales Date

Los Angeles $1500 Jan-05-1999

San Diego $250 Jan-07-1999

Los Angeles $300 Jan-08-1999

Boston $700 Jan-08-1999

Internet Sales 表格

Date Sales

Jan-07-1999 $250

Jan-10-1999 $535

Jan-11-1999 $320

Jan-12-1999 $750

而我们要找出来所有有营业额 (sales) 的日子。要达到这个目的,我们用以下的 SQL 语句: SELECT Date FROM Store_Information

UNION

SELECT Date FROM Internet_Sales 结果:

Date

Jan-05-1999

Jan-07-1999

Jan-08-1999

Jan-10-1999

Jan-11-1999

Jan-12-1999

有一点值得注意的是,如果我们在任何一个 SQL 语句 (或是两句都一起) 用 "SELECT DISTINCT Date" 的话,那我们会得到完全一样的结果。

SQL Union All

UNION ALL 这个指令的目的也是要将两个 SQL 语句的结果合并在一起。 UNION ALL 和 UNION 不同之处在于 UNION ALL 会将每一笔符合条件的资料都列出来,无论资料值有无重复。 UNION ALL 的语法如下: [SQL 语句 1]

UNION ALL

[SQL 语句 2] 我们用和上一页同样的例子来显示出 UNION ALL 和 UNION 的不同。同样假设我们有以下两个表格,

Store_Information 表格

store_name Sales Date

Los Angeles $1500 Jan-05-1999

San Diego $250 Jan-07-1999

Los Angeles $300 Jan-08-1999

Boston $700 Jan-08-1999

Internet Sales 表格

Date Sales

Jan-07-1999 $250

Jan-10-1999 $535

Jan-11-1999 $320

Jan-12-1999 $750

而我们要找出有店面营业额以及网络营业额的日子。要达到这个目的,我们用以下的 SQL 语句: SELECT Date FROM Store_Information

UNION ALL

SELECT Date FROM Internet_Sales 结果:

Date

Jan-05-1999

Jan-07-1999

Jan-08-1999

Jan-08-1999

Jan-07-1999

Jan-10-1999

Jan-11-1999

Jan-12-1999

UNION 指令的目的是将两个 SQL 语句的结果合并起来。从这个角度来看, UNION 跟 JOIN 有些许类似,因为这两个指令都可以由多个表格中撷取资料。 UNION 的一个限制是两个 SQL 语句所产生的栏位需要是同样的资料种类。另外,当我们用 UNION这个指令时,我们只会看到不同的资料值 (类似 SELECT DISTINCT)。 SELECT Date FROM Store_Information

UNION

SELECT Date FROM Internet_Sales 注意 ,如果我们在任何一个 SQL 语句 (或是两句都一起) 用 "SELECT DISTINCT Date" 的话,那我们会得到完全一样的结果。

c语言中的结构(struct)和联合(union)简介。 else pf->next=pi

pi->next=pb

}

else

{

pb->next=pi

pi->next=NULL

}

}

return head

}

void print(TYPE * head)

{

printf("Number\t\tAge\n")

while(head!=NULL)

{

printf("%d\t\t%d\n",head->num,head->age)

head=head->next

}

}

main()

{

TYPE * head,*pnum

int n,num

printf("input number of node: ")

scanf("%d",&n)

head=creat(n)

print(head)

printf("Input the deleted number: ")

scanf("%d",&num)

head=delete(head,num)

print(head)

printf("Input the inserted number and age: ")

pnum=(TYPE *)malloc(LEN)

scanf("%d%d",&pnum->num,&pnum->age)

head=insert(head,pnum)

print(head)

}

[/code:1:8d8ee8c82c]

本例中,print函数用于输出链表中各个结点数据域值?男尾蝖ead的初值指向链表第一个结点。在while语句中,输出结点值后, head值被改变,指向下一结点。若保留头指针head, 则应另设一个指针变量,把head值赋予它,再用它来替代head。在main函数中,n为建立结点的数目, num为待删结点的数据域值head为指向链表的头指针,pnum为指向待插结点的指针。 main函数中各行的意义是:

第六行输入所建链表的结点数

第七行调creat函数建立链表并把头指针返回给head

第八行调print函数输出链表

第十行输入待删结点的学号

第十一行调delete函数删除一个结点

第十二行调print函数输出链表

第十四行调malloc函数分配一个结点的内存空间, 并把其地址赋予pnum

第十五行输入待插入结点的数据域值

第十六行调insert函数插入pnum所指的结点

第十七行再次调print函数输出链表。

从运行结果看,首先建立起3个结点的链表,并输出其值再删103号结点,只剩下105,108号结点又输入106号结点数据, 插入后链表中的结点为105,106,108。联合“联合”也是一种构造类型的数据结构。 在一个“联合”内可以定义多种不同的数据类型, 一个被说明为该“联合”类型的变量中,允许装入该“联合”所定义的任何一种数据。 这在前面的各种数据类型中都是办不到的。例如, 定义为整型的变量只能装入整型数据,定义为实型的变量只能赋予实型数据。

在实际问题中有很多这样的例子。 例如在学校的教师和学生中填写以下表格: 姓 名 年 龄 职 业 单位 “职业”一项可分为“教师”和 “学生”两类。 对“单位”一项学生应填入班级编号,教师应填入某系某教研室。 班级可用整型量表示,教研室只能用字符类型。 要求把这两种类型不同的数据都填入“单位”这个变量中, 就必须把“单位”定义为包含整型和字符型数组这两种类型的“联合”。

“联合”与“结构”有一些相似之处。但两者有本质上的不同。在结构中各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在 “联合”中,各成员共享一段内存空间, 一个联合变量的长度等于各成员中最长的长度。应该说明的是, 这里所谓的共享不是指把多个成员同时装入一个联合变量内, 而是指该联合变量可被赋予任一成员值,但每次只能赋一种值, 赋入新值则冲去旧值。如前面介绍的“单位”变量, 如定义为一个可装入“班级”或 “教研室”的联合后,就允许赋予整型值(班级)或字符串(教研室)。要么赋予整型值,要么赋予字符串,不能把两者同时赋予它。联合类型的定义和联合变量的说明一个联合类型必须经过定义之后, 才能把变量说明为该联合类型。

一、联合的定义

定义一个联合类型的一般形式为:

union 联合名

{

成员表

}

成员表中含有若干成员,成员的一般形式为: 类型说明符 成员名 成员名的命名应符合标识符的规定。

例如:

union perdata

{

int class

char office[10]

}

定义了一个名为perdata的联合类型,它含有两个成员,一个为整型,成员名为class另一个为字符数组,数组名为office。联合定义之后,即可进行联合变量说明,被说明为perdata类型的变量,可以存放整型量class或存放字符数组office。

二、联合变量的说明

联合变量的说明和结构变量的说明方式相同, 也有三种形式。即先定义,再说明定义同时说明和直接说明。以perdata类型为例,说明如下:

union perdata

{

int class

char officae[10]

}

union perdata a,b/*说明a,b为perdata类型*/

或者可同时说明为:

union perdata

{

int class

char office[10]

}a,b

或直接说明为:

union

{

int class

char office[10]

}a,b

经说明后的a,b变量均为perdata类型。 它们的内存分配示意图如图7—8所示。a,b变量的长度应等于 perdata 的成员中最长的长度, 即等于

office数组的长度,共10个字节。从图中可见,a,b变量如赋予整型值时,只使用了2个字节,而赋予字符数组时,可用10个字节。

联合变量的赋值和使用

对联合变量的赋值,使用都只能是对变量的成员进行。 联合变量的成员表示为: 联合变量名.成员名 例如,a被说明为perdata类型的变量之后,可使用 a.class a.office 不允许只用联合变量名作赋值或其它 *** 作。 也不允许对联合变量作初始化赋值,赋值只能在程序中进行? 挂偾康魉得鞯氖?一个联合变量, 每次只能赋予一个成员值?痪浠八?一个联合变量的值就是联合变员的某一个成员值。

[例7.15]设有一个教师与学生通用的表格,教师数据有姓名,年龄,职业,教研室四项。学生有姓名,年龄,职业,班级四项。

编程输入人员数据, 再以表格输出。

[code:1:8d8ee8c82c]

main()

{

struct

{

char name[10]

int age

补充:你可以自己去电脑编程网看看,那里很多这电脑编程方面的知识

中国物联网校企联盟技术部


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9963305.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存