MySQL视图整合两张表数据(mysql两张表视图)


MySQL视图:整合两张表数据

在MySQL数据库中,有时候需要整合两张表的数据,以便于进行查询和分析。这时,可以使用MySQL视图来完成。MySQL视图可以将多张表的数据整合起来,形成一个虚拟的表,方便查询和管理。

下面我们来看一个具体的例子。假设我们有两张表,一张是用户信息表,包含了用户的姓名、年龄、性别和电话等信息。另一张是订单信息表,包含了订单的编号、下单日期、订单状态和订单金额等信息。现在我们需要整合这两张表的数据,以便于查看每个用户的订单信息。

我们需要创建这两张表。可以使用以下的SQL语句来创建。

CREATE TABLE `user_info` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(50) DEFAULT NULL,

`age` int(11) DEFAULT NULL,

`gender` varchar(10) DEFAULT NULL,

`phone` varchar(50) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

CREATE TABLE `order_info` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`user_id` int(11) DEFAULT NULL,

`order_no` varchar(50) DEFAULT NULL,

`order_date` datetime DEFAULT NULL,

`order_status` varchar(20) DEFAULT NULL,

`order_amount` decimal(10,2) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

接下来,我们需要往这两张表中插入一些数据,可以使用以下的SQL语句来插入。

INSERT INTO `user_info` (`name`, `age`, `gender`, `phone`) VALUES

(‘张三’, 20, ‘男’, ‘13512345678’),

(‘李四’, 25, ‘女’, ‘13612345678’),

(‘王五’, 30, ‘男’, ‘13712345678’);

INSERT INTO `order_info` (`user_id`, `order_no`, `order_date`, `order_status`, `order_amount`) VALUES

(1, ‘202101010001’, ‘2021-01-01 10:10:10’, ‘已支付’, 100.00),

(1, ‘202101020002’, ‘2021-01-02 11:11:11’, ‘已发货’, 200.00),

(2, ‘202101030003’, ‘2021-01-03 12:12:12’, ‘已取消’, 300.00),

(2, ‘202101040004’, ‘2021-01-04 13:13:13’, ‘已完成’, 400.00),

(3, ‘202101050005’, ‘2021-01-05 14:14:14’, ‘已支付’, 500.00);

接下来,我们需要创建一个视图来整合这两张表的数据。可以使用以下的SQL语句来创建视图。

CREATE VIEW `user_order` AS

SELECT u.`id`, u.`name`, o.`order_no`, o.`order_date`, o.`order_status`, o.`order_amount`

FROM `user_info` u

LEFT JOIN `order_info` o ON u.`id`=o.`user_id`;

这个视图把用户信息表和订单信息表按照用户ID关联起来,将它们的数据整合在一起。现在,我们可以用这个视图来查询每个用户的订单信息了。可以使用以下的SQL语句来查询。

SELECT * FROM `user_order`;

以上SQL语句将返回以下结果。

+—-+——–+————–+———————+————-+—————+

| id | name | order_no | order_date | order_status| order_amount |

+—-+——–+————–+———————+————-+—————+

| 1 | 张三 | 202101010001 | 2021-01-01 10:10:10 | 已支付 | 100.00 |

| 1 | 张三 | 202101020002 | 2021-01-02 11:11:11 | 已发货 | 200.00 |

| 2 | 李四 | 202101030003 | 2021-01-03 12:12:12 | 已取消 | 300.00 |

| 2 | 李四 | 202101040004 | 2021-01-04 13:13:13 | 已完成 | 400.00 |

| 3 | 王五 | 202101050005 | 2021-01-05 14:14:14 | 已支付 | 500.00 |

+—-+——–+————–+———————+————-+—————+

以上结果显示了每个用户的订单信息,包括订单号、下单时间、订单状态和订单金额等信息。

综上所述,使用MySQL视图可以方便地整合两张表的数据,使得查询和分析更加方便。在实际应用中,根据需要可以创建多个视图,以满足不同的查询和分析需求。