最经做项目时发现的问题,好像在update时也有... 网上查到的资料如下: 1.使用mysql进行delete from操作时,若子查询的 FROM 字句和更新/删除对象使用同一张表,会出现错误. mysql> DELETE FROM tab1 WHERE col1 = ( SELECT MAX( col1 ) FROM tab1 ); ERROR 1093 (HY000): You can’t specify target table ‘tab1′ for update in FROM cl…
mysql在Update带有子查询的时候,子查询的表会锁住,导致该表无法使用.比如 update A set comments = (select count(1) from B where id = A.id) where id = 123; 把B表给锁住了.   而在Oracle里不存在这种情况 . 最后发现 mysql 默认的隔离级别是REPEATABLE-READ,oracle默认数据隔离级别是 READ-COMMITTED .所以在mysq中 update ... select * f…
1. Select- subquery子查询 子查询:是将一条查询语句嵌套在另一条查询语句之中. 2. 案例 需求:查询获得代课天数最多的那个老师的信息. 思路:先获得最多的代课天数是多少天,然后再判断哪个老师的代课天数和最大值是一样的.MySQL允许将上面的查询结果,作为一个值来使用. 即: var1 = Select max(days) from teacher_class:/* 保存起来 */ Select  t_name,gender from teacher_class where d…
子查询: 子查询,即嵌套在其他查询中的查询.例如我们有这样几个表,顾客表,订单表,商品表,我们想知道有哪些客户买了商品A,那么我们就需要先查看哪些订单里包含了商品A,然后根据订单查出是哪些客户. mysql> select cust_id from orders where order_num in (select order_num from orderitems where prod_id = '1'); +---------+ | cust_id | +---------+ |    10…
前几天看别人的代码中看到在字段中使用select子查询的方法,第一次见这种写法,然后研究了一下,记录下来 大概的形式是这样的: select a .*,(select b.another_field from b where a.id=b.aid) another_field from a where 1 limit 10; 下面还是以实例来说明,要不然不好理解,新建两张表,一张是商品表,另外一张是商品的评论表 商品表: CREATE TABLE `product` ( `id` int(11)…
union查询就是把2条或者多条sql语句的查询结果,合并成一个结果集. 如:sql1: N行,sql2: M行,sql1 union sql2 ---> N+M行 1.能否从2张表查询再union呢? 可以,union 合并的是"结果集",不区分在自于哪一张表. 2.取自于2张表,通过"别名"让2个结果集的列一致.那么,如果取出的结果集,列名字不一样,还能否union. 可以,而且取出的最终列名,以第1条sql为准 3.union满足什么条件就可以用了? 只…
知识点八:子查询(42) 什么是子查询: 子查询是将一个查询语句嵌套在另一个查询语句中.内层查询语句的查询结果,可以作为外层查询语句提供条件. 引发子查询的情况: 使用[NOT] IN 的子查询 --删除原本的员工表和部门表,重新建 DROP TABLE employee,department; CREATE TABLE IF NOT EXISTS department( id TINYINT UNSIGNED AUTO_INCREMENT KEY, depName ) NOT NULL UNI…
1.子查询简介 其中,所谓的“外层查询”并不是指“查找”,指的是所有SQL语句的统称:结构化查询语言(Structured Query Language),简称SQL. : 2.由比较运算符引发的子查询             注意:当子查询返回多个结果的时候,可以用ANY.SOME.ALL修饰,ANY.SOME是等价的:符合返回结果中的一个即可:ALL:符合全部结果.    3.由[NOT]IN/EXISTS引发的子查询      4.使用INSERT...SELECT插入记录    5.多表…
参考文章https://zhuanlan.zhihu.com/p/41844742 成绩表如下Score: 问题:查询科目中成绩大于平均成绩的记录? SELECT * FROM Score WHERE score > ( SELECT AVG(score) FROM Score GROUP BY courseid ); 上述SQL语句是错误的,因为子查询结果分别为三个科目的平均成绩,与score无法进行比较. 正确SQL语句如下:SELECT * SELECT * FROM Score as a…
UPDATE t_commission_template tctJOIN ( SELECT max(id) maxid FROM t_commission_template WHERE taken_mode = 1 AND t_commission_id = 6 GROUP BY contract) temp ON temp.maxid = tct.idSET tct.open_position_bymoney = 0, tct.open_position_bylot = 0, tct.clos…