⑴ sql语句怎么处理两个不同字段链接同一个表的情况
selectc.id,a.公司名称AS甲方公司,b.公司名称AS乙方公司,c.合同编号
fromUnita,Unitb,Contractc
wherea.id=c.甲方IDandb.id=c.乙方ID
就是说一个UNIT表要同时被关联2次,一次为甲用,一次为乙用
⑵ sql 连接两个表,但有两个字段名重复,调出问题
不对,你应该使用表链接
select B.[name] from a A left join b B
on A.tid=B.tid where A.parentid=1
⑶ 能不能用sql语句将两张字段相同的表连接起来
select * from 表1 where 条件 union select * from 表2 where 条件
⑷ SQL语句中两个表的连接
1、打开数据库管理工具,在数据库中新建两个表用于测试,这里,两个表的表结构要一样,分别建立TEST 和 TEST1。
⑸ sql语句如何查询一个表中某两个字段的相同数据
查询一个表中某两个字段的相同数据代码是:Select Name,ID From A group by Name,ID having count (*)>1。
结构化查询语言(Structured Query Language)简称SQL,结构化查询语言是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;
sql 语句就是对数据库进行操作的一种语言。
sql="select * from 数据表 where字段名=字段值 order by字段名[desc]"(按某个字段值降序排列,默认升序ASC);
sql="select * from 数据表 where字段名like '%字段值%' order by 字段名 [desc]";
sql="select top 10 * from 数据表 where字段名=字段值 order by 字段名 [desc]";
sql="select top 10 * from 数据表 order by 字段名 [desc]";
sql="select * from 数据表 where字段名in ('值1','值2','值3')";
sql="select * from 数据表 where字段名between 值1 and 值2"。
sql语句:
更新:update table1 set field1=value1 where 范围;
查找:select * from table1 where field1 like '%value1%' (所有包含'value1'这个模式的字符串);
排序:select * from table1 order by field1,field2 [desc];
求和:select sum(field1) as sumvalue from table1;
平均:select avg(field1) as avgvalue from table1;
最大:select max(field1) as maxvalue from table1;
最小:select min(field1) as minvalue from table1[separator]。
⑹ SQL一个表里有另一个表里两个相同字段.
select a.name as 操作人,b.name as 被操作人
from cz
left join stu a on a.id=cz.czid
left join stu b on b.id=cz.bczid
⑺ 请教下:关于sql方面,我想做多表连接查询,是不是两个表之间必须要有相同字段呢才能连接查询呢
可以这样,连接用字段只是要求数据类型兼容就可以了,你的可以连接,但是结果可能很荒唐或者为空集,大多数情况下连接字段都是主码和外码,但是用于比较的等值与不等值连接没有这个习惯
⑻ 如何用SQL语句将表中两个字段相同的记录取出
sql语句同步两个表中的字段值需要用触发器来实现。如有两张表——a表和b表,创建触发器使当a表插入数据后b表也同步插入数据。其中b表插入数据的字段需要同a表中的字段相对应。create
trigger
触发器名称
on
a表after
insert
as
begin
insert
into
b表(b表字段1,b表字段2,b表字段3)select
a表字段1,a表字段2,a表字段3
from
insertedend
⑼ sql查询两个字段相同的记录
EXCEL中用VBA连接ACCESS数据库
有如下一张表,要分别查找出所有同名的人、所有同名并且学号也一样的人以及所有同名但不同学号的人。
查询所有同名人员
select * from [18年考试成绩] where [姓名] in (SELECT [姓名] FROM [18年考试成绩] group by [姓名] having count(姓名)>1)
查询结果:
查找所有姓名和学号两个字段都重复的人
select * from [18年考试成绩] where [姓名] in (SELECT [姓名] FROM [18年考试成绩] group by [姓名] having count(姓名)>1) and [学号] in (SELECT [学号] FROM [18年考试成绩] group by [学号] having count(学号)>1)
查询结果:
查找所有姓名重复但学号不重复的人
select * from [18年考试成绩] where [姓名] in (SELECT [姓名] FROM [18年考试成绩] group by [姓名] having count(姓名)>1) and [学号] not in (SELECT [学号] FROM [18年考试成绩] group by [学号] having count(学号)>1)
注意:要把SELECT查询子句配合in或not in 操作符使用,SELECT查询子句只能有一列内容。
查询结果:
其中子句 “SELECT [姓名] FROM [18年考试成绩] group by [姓名] having count(姓名)>1”是显示所有重复的姓名,如果如下:
如果要知道重复出现次数,则可以这样写:
SELECT [姓名],count(姓名) as 出现次数 FROM [18年考试成绩] group by [姓名] having count(姓名)>1
结果如下:
查找唯一记录
group by [姓名],意思是按姓名分组,having count(姓名)>1 是分组条件,意思是姓名次数出现2次以上的重复内容以姓名进行分组,前面的count(姓名)是对分组以后的姓名统计出现次数。在后面要使用函数条件时应该使用having,而不是使用where
查找唯一值,比如本例的班级中,只有一个“四班”,要把这个四班的所有字段显示出来可以这样:
select * from [18年考试成绩] where 班级 not in (SELECT 班级 FROM [18年考试成绩] group by 班级 having count(班级)>1)
结果:
如果使用“SELECT DISTINCT 班级 FROM [18年考试成绩]”语句查询唯一值,结果将会如下:
DISTINCT 会显示不重复的值,如果有重复的,只显示第一个,所以如果需要显示仅出现一次的值并不适合使用SELECT DISTINCT语句
分组查询语句:
比如要班级为单位,查询每个班的总人数,科目总分,科目平均分等
SELECT [班级],count(姓名) as 班级人数,sum(语文) as 语文总成绩,sum(数学) as 数学总成绩,ROUND(avg(语文),1) as 语文平均分,ROUND(avg(数学),1) as 数学平均分 FROM [18年考试成绩] group by [班级]
查询结果如下:
注意:如果使用函数的字段,不使用AS指定别名,将会自动生成一个字段名,第一列名字Expr1000,第二列名为Expr1001,第三列名为Expr1002,以此类推
如:
SELECT [班级],count(姓名),sum(语文),sum(数学),ROUND(avg(语文),1) ,ROUND(avg(数学),1) FROM [18年考试成绩] group by [班级]
查询结果如下:
如果不指定别名,你将无法清楚在查询结果中知道每一列是干什么的。
如果需要再细分,查询每个班女生总人数和科目平均分,只需要再加一个where条件就可以了
SELECT [班级],count(姓名) as 班级女性人数,ROUND(avg(语文),1) as 语文平均分,ROUND(avg(数学),1) as 数学平均分 FROM [18年考试成绩] where 性别='女' group by [班级]
⑽ SQL查询2个表中有2个相同的字段
select * from A,B where A.M=B.M and A.N=B.N