2 ycn5202005 ycn5202005 于 2016.02.26 15:38 提问

mysql left join 如何使用

有三张表:products、orders、order_product

create table products(
product_code varchar(20) primary key not null,
product_name varchar(20),
product_price float
);

create table orders(
order_id varchar(40) primary key not null,
order_status enum('0','1','2') default '0',
);

create table order_product(
order_id varchar(40) primary key not null,
product_code varchar(20)
foreign key(order_id) references orders(order_id),
foreign key(product_code) references products(product_code)
);

问题1:查询 order_product 表(只要有一条记录就行),要求 order_product.product_code='1111111' 并且 order_product.order_id 在 orders 表里已存在,并且 orders.order_status='0'?

我的写法:SELECT * FROM orders_product AS op LEFT JOIN orders AS od ON op.product_id=od.product_id WHERE op.product_code='1111'AND od.order_status='0' LIMIT 1;

结果报 1045 错误,请高手指点,非常感谢!

5个回答

Mr_dsw
Mr_dsw   Ds   Rxr 2016.02.26 17:05
已采纳
 SELECT * FROM order_product AS op LEFT JOIN orders AS od 
ON 
op.order_id=od.order_id WHERE op.product_code='111111'AND od.order_status='2' LIMIT 1;

这样写就可以了,对于order_product表中压根没有product_id字段,你怎么进行关联啊!换成order_id进行挂链。
图片说明

ycn5202005
ycn5202005 谢谢你的回答,我上传的代码有点问题,问题已经解决。有问题再请教你。
接近 2 年之前 回复
zy7257775
zy7257775   2016.02.26 15:45

换成INNER JOIN..ON 试试

ycn5202005
ycn5202005 还是 1054 错误
接近 2 年之前 回复
Royal_lr
Royal_lr   Ds   Rxr 2016.02.26 16:20

limit 1?,,应该是limit a,b,,,从第a条到第b条数据吧,,,

yizhi_biu
yizhi_biu limit a,b是从a开始的b条数据,不是到b为止,limit 1是可以用的
接近 2 年之前 回复
yizhi_biu
yizhi_biu limit a,b是从a开始的b条数据,不是到b为止,limit 1是可以用的
接近 2 年之前 回复
yizhi_biu
yizhi_biu   2016.02.26 16:28

1045是登陆问题诶

nohaoye
nohaoye   2016.02.26 19:39
SELECT * FROM order_product AS op LEFT JOIN orders AS od ON op.order_id = od.order_id WHERE op.order_id='1111'AND od.order_status='0' LIMIT 1;

你自己写的命名都乱套了....

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!