一使用SELECT子句进行多表查询SELECT 字段名 FROM 表1,表2 … WHERE 表1字段 = 表2字段 AND 其它查询条件SELECT a.id,a.name,a.address,a.date,b.math,b.english,b.chinese FROM tb_demo065_tel AS b,tb_demo065 AS a WHERE a.id=b.id
网站建设哪家好,找创新互联!专注于网页设计、网站建设、微信开发、微信小程序、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了青冈免费建站欢迎大家使用!
注:在上面的的代码中,以两张表的id字段信息相同作为条件建立两表关联,但在实际开发中不应该这样使用,最好用主外键约束来实现。
1、联合查询可合并多个相似的选择查询的结果集。等同于将一个表追加到另一个表,从而实现将两个表的查询组合到一起,使用谓词为UNION或UNION ALL。联合查询时,查询结果的列标题为第一个查询语句的列标题。因此,要定义列标题必须在第一个查询语句中定义。要对联合查询结果排序时,也必须使用第一查询语句中的列名、列标题或者列序号。
2、在使用UNION 运算符时,应保证每个联合查询语句的选择列表中有相同数量的表达式,并且每个查询选择表达式应具有相同的数据类型,或是可以自动将它们转换为相同的数据类型。在自动转换时,对于数值类型,系统将低精度的数据类型转换为高精度的数据类型。
3、在包括多个查询的UNION语句中,其执行顺序是自左至右,使用括号可以改变这一执行顺序。例如:查询1 UNION (查询2 UNION 查询3)。
delete from table 使用这个语句即可。
你可以一个一个的删除,意思就是说一条语句清空一个表所对应的数据。关不关联无所谓。
注意的是:
删除的时候,由内 向 外 删 就可以达到目的
什么是由内向外,
比如一个订单表 和 订单明细表
那么你应该先删出订单明细表,然后再删除订单表中的数据,就会操作正确;
如果你先删订单,后删订单明细,就会报错,报错的原因就是因为逻辑问题。
Select b.* from a,b where a.id=8976 and a.xid=b.id
这样就好了,查询出来的是b表的内容,关联条件是xid和b表的id。
给你一个参考的例子, 你参照着, 创建一个 外键约束就可以了。
首先是测试的表结构与测试数据, 和你的例子一样, 是3列。
分别为: id, 父id, 数据
CREATE TABLE test_self (
id INT NOT NULL,
pid INT,
value VARCHAR(10),
PRIMARY KEY(id)
);
INSERT INTO test_self VALUES(1, NULL, '.NET');
INSERT INTO test_self VALUES(2, 1, 'C#');
INSERT INTO test_self VALUES(3, 1, 'J#');
INSERT INTO test_self VALUES(4, 1, 'ASP.NET');
INSERT INTO test_self VALUES(5, 1, 'VB.NET');
INSERT INTO test_self VALUES(6, NULL, 'J2EE');
INSERT INTO test_self VALUES(7, 6, 'EJB');
INSERT INTO test_self VALUES(8, 6, 'Servlet');
INSERT INTO test_self VALUES(9, 6, 'JSP');
INSERT INTO test_self VALUES(10, NULL, 'Database');
INSERT INTO test_self VALUES(11, 10, 'DB2');
INSERT INTO test_self VALUES(12, 10, 'MySQL');
INSERT INTO test_self VALUES(13, 10, 'Oracle');
INSERT INTO test_self VALUES(14, 10, 'SQL Server');
INSERT INTO test_self VALUES(15, 13, 'PL/SQL');
INSERT INTO test_self VALUES(16, 15, 'Function');
INSERT INTO test_self VALUES(17, 15, 'Procedure');
INSERT INTO test_self VALUES(18, 15, 'Package');
INSERT INTO test_self VALUES(19, 15, 'Cursor');
INSERT INTO test_self VALUES(20, 14, 'T-SQL');
下面是 创建 外键约束, 和 测试删除 父节点, 同时删除子节点的处理。
mysql ALTER TABLE test_self
- ADD CONSTRAINT fk_test_self
- FOREIGN KEY (pid) REFERENCES test_self(id) ON DELETE CASCADE;
Query OK, 20 rows affected (0.05 sec)
Records: 20 Duplicates: 0 Warnings: 0
-- 测试 级联删除 层次为 1层的. (预期结果是 id=1,2,3,4,5 的被删除. )
mysql DELETE FROM test_self WHERE ID = 1;
Query OK, 1 row affected (0.07 sec)
-- 数据核对.
mysql select * from test_self;
+----+------+------------+
| id | pid | value |
+----+------+------------+
| 6 | NULL | J2EE |
| 7 | 6 | EJB |
| 8 | 6 | Servlet |
| 9 | 6 | JSP |
| 10 | NULL | Database |
| 11 | 10 | DB2 |
| 12 | 10 | MySQL |
| 13 | 10 | Oracle |
| 14 | 10 | SQL Server |
| 15 | 13 | PL/SQL |
| 16 | 15 | Function |
| 17 | 15 | Procedure |
| 18 | 15 | Package |
| 19 | 15 | Cursor |
| 20 | 14 | T-SQL |
+----+------+------------+
15 rows in set (0.00 sec)
-- 测试 级联删除 层次为 多层的. (预期结果是 id=10 与 10以后 的被删除. )
mysql DELETE FROM test_self WHERE ID = 10;
Query OK, 1 row affected (0.01 sec)
mysql select * from test_self;
+----+------+---------+
| id | pid | value |
+----+------+---------+
| 6 | NULL | J2EE |
| 7 | 6 | EJB |
| 8 | 6 | Servlet |
| 9 | 6 | JSP |
+----+------+---------+
4 rows in set (0.00 sec)