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币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
mysql left join和union结合的用法
left join和union结合的用法 子查询union 然后加个括号设置个别名 (union自动去除 重复的 ) select o.nickName,o.sex,o.province,o.city,from_unixtime(m.time,'%Y-%m-%d %H:%i:%s') as starttime,from_unixtime(z.time,'%Y-%m-%d %H
mysql 优化-子查询和left join(一)
今天针对一个mysql做优化 具体如下设计到几张表 商品表: goods 会员消费表:member_consumes 会员表: members 会员标签表member_label 分组标签表: group_label 大体功能是这样的在分组营销的分组数据下面查看会员消费前十的商品是哪些 比如:在孕妇装分组下面会员买的最多的是那些牌子的商品 之前的sql语句是这样的SELEC
mysql join 和left join 对于索引的问题
今天遇到一个left join优化的问题,搞了一下午,中间查了不少资料,对MySQL的查询计划还有查询优化有了更进一步的了解,做一个简单的记录:  select c.* from hotel_info_original c  left join hotel_info_collection h  on c.hotel_type=h.hotel_type and c.hotel_id =h.
MySQL - MySQL如何优化LEFT JOIN和RIGHT JOIN
MySQL - MySQL如何优化LEFT JOIN和RIGHT JOIN [MySQL如何优化LEFT JOIN和RIGHT JOIN文档] http://dev.mysql.com/doc/refman/5.1/zh/optimization.html#left-join-optimization [MySQL网站] http://www.mys
数据库优化<三>SQL优化之SELECT优化 ——JOIN和LEFT JOIN 和 RIGHT JOIN
在数据库的应用中,我们经常需要对多表进行连表操作来获得关系型的数据,因此,应该更加的掌握好 SQL语句的join原理,因为,可以稍一不慎,可能一个不好的join导致数据库的全表扫描,查询出大量的 无用的信息,并且对数据库性能影响极大。          数据库中的join操作,实际上是对一个表和另一个表的
mysql 中LEFT JOIN基本用法实例
/*SQL 中LEFT JOIN的含义是__,如果 tbl_user记录了学生的姓名(name)和学号(ID), tbl_score记录了学生(有的学生考试以后被开除了,没有其记录)的学号(ID)和考试成绩(score)以及考试科目(subject),要想打印出各个学生姓名及对应的的各科总成绩,则可以用SQL语句____. 答:自然左外连接*/ create database phpintervi
mysql update 的时候使用left join和where语句
在使用update语句的时候我们有时候需要利用left join 关联表,以下是正确操作: 效果,让指定的order表id为1,2,3数据的finish_at字段更新为freports表的created_at字段UPDATE orders LEFT JOIN freports ON freports.order_id = orders.id set orders.finish_at = frep
mysql中高效查询(left join 和 group by),前提是加了索引
mysql中高效查询(left join 和 group by)
mysql left join,right join,inner join超详细用法分析
mysql left join,right join,inner join超详细用法分析 下面是例子分析 表A记录如下:  aID        aNum  1           a20050111  2           a20050112  3           a20050113  4           a20050114  5    
关于 MySQL LEFT JOIN 你可能需要了解的三点(受益匪浅)
https://www.oschina.net/question/89964_65912