当前位置:首页 » 编程语言 » sql表的关联

sql表的关联

发布时间: 2024-07-20 18:30:39

‘壹’ SQL数据库关联是什么怎么用

使用外联接
仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行。内联接消除与另一个表中的任何行不匹配的行。而外联接会返回
FROM
子句中提到的至少一个表或视图的所有行,只要这些行符合任何
WHERE

HAVING
搜索条件。将检索通过左向外联接引用的左表的所有行,以及通过右向外联接引用的右表的所有行。完整外部联接中两个表的所有行都将返回。

Microsoft®
SQL
Server™
2000
对在
FROM
子句中指定的外联接使用以下
SQL-92
关键字:

LEFT
OUTER
JOIN

LEFT
JOIN
RIGHT
OUTER
JOIN

RIGHT
JOIN
FULL
OUTER
JOIN

FULL
JOIN

SQL
Server
支持
SQL-92
外联接语法,以及在
WHERE
子句中使用
*=

=*
运算符指定外联接的旧式语法。由于
SQL-92
语法不容易产生歧义,而旧式
Transact-SQL
外联接有时会产生歧义,因此建议使用
SQL-92
语法。
使用左向外联接
假设在
city
列上联接
authors
表和
publishers
表。结果只显示在出版商所在城市居住的作者(本例中为
Abraham
Bennet

Cheryl
Carson)。

若要在结果中包括所有的作者,而不管出版商是否住在同一个城市,请使用
SQL-92
左向外联接。下面是
Transact-SQL
左向外联接的查询和结果:
USE
pubs
SELECT
a.au_fname,
a.au_lname,
p.pub_name
FROM
authors
a
LEFT
OUTER
JOIN
publishers
p
ON
a.city
=
p.city
ORDER
BY
p.pub_name
ASC,
a.au_lname
ASC,
a.au_fname
ASC

‘贰’ 如何设置SQL数据库表与表的关联关系

如果是 父子关系, 或者 一对多 关系。

可以通过 创建外键的方式, 在 父表 与 子表之间, 创建一个关联关系。

例如:

-- 创建测试主表. ID 是主键.
CREATE TABLE test_main (
id INT NOT NULL,
value VARCHAR(10),
PRIMARY KEY(id)
);

-- 创建测试子表.
CREATE TABLE test_sub (
id INT NOT NULL,
main_id INT ,
value VARCHAR(10),
PRIMARY KEY(id)
);

-- 插入测试主表数据.
INSERT INTO test_main(id, value) VALUES (1, 'ONE');
INSERT INTO test_main(id, value) VALUES (2, 'TWO');

-- 插入测试子表数据.
INSERT INTO test_sub(id, main_id, value) VALUES (1, 1, 'ONEONE');
INSERT INTO test_sub(id, main_id, value) VALUES (2, 2, 'TWOTWO');

SQL> -- 创建外键(默认选项)
SQL> ALTER TABLE test_sub ADD CONSTRAINT main_id_cons FOREIGN KEY (main_id) REFERENCES test_main;

Table altered.

SQL>
SQL> -- 测试删除主表数据. 将出错 ORA-02292: 违反完整约束条件
SQL> DELETE
2 test_main
3 WHERE
4 ID = 1;
DELETE
*
ERROR at line 1:
ORA-02292: integrity constraint (HR.MAIN_ID_CONS) violated - child record found

热点内容
php注册与登录 发布:2024-11-26 07:31:21 浏览:795
基金账户如何配置 发布:2024-11-26 07:29:58 浏览:180
用电脑怎么刷汽车行车电脑配置 发布:2024-11-26 07:24:14 浏览:688
客户端ip和服务器ip地址怎么设置 发布:2024-11-26 07:18:25 浏览:684
如何破解加密的wmv 发布:2024-11-26 07:18:16 浏览:895
资源码项目 发布:2024-11-26 07:10:12 浏览:892
acl配置第三步如何验证 发布:2024-11-26 07:07:58 浏览:939
上传gif搜索 发布:2024-11-26 06:27:05 浏览:763
linux用户组文件 发布:2024-11-26 06:26:58 浏览:89
java接口编程 发布:2024-11-26 06:25:23 浏览:155