mysql 查询语句

1> 查询数据表除了前三条以外的数据。

   起初我想到的是这条语句

   SELECT * FROM admin WHERE userid NOT IN (SELECT userid FROM admin ORDER BY userid LIMIT 3) ORDER BY userid DESC 

  但是运行的时候会报 This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery

这个的意思是表示子查询的时候不支持limit ,还有一点我就是很二了 就是查询的时候用not in 效率非常不高

最后的解决办法是

    CREATE VIEW view_top3_admin AS SELECT * FROM admin ORDER BY userid LIMIT 3;

先创建一个视图 将子查询条件放到视图里面

  然后在用这条语句

 SELECT * FROM admin a WHERE NOT EXISTS (SELECT 1 FROM view_top3_admin b WHERE b.userid=a.userid ) ORDER BY a.userid DESC

 先来解释下这条语句  SELECT 1 FROM view_top3_admin b WHERE b.userid=a.userid  表示查询表里面的值 只要有数据都显示为 1,1表示不读取数据

这样的话就是提升了查询的性能,当然也可以把 里面的1  换成 null 性能是一致的。整条语句的意思是查询admin表值, 判断条件是值不在子查询表里的。

 

 

2 > union 和 union all 的使用

 

先来解释下这两个关键字在mysql数据库中提供了UNION和UNION ALL关键字,这两个关键字都是将结果集合并为一个,但这两者从使用和效率上来说都有所不同

UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果。

select * from table union select * from tabl

UNION ALL只是简单的将两个结果合并后就返回 如果返回的两个结果集中有重复的数据,那么返回的结果集就会包含重复的数据了

select * from table union all select * from tabl

从效率上说,UNION ALL 要比UNION快很多,所以,如果可以确认合并的两个结果集中不包含重复的数据的话,那么就使用UNION 

这两个关键字用做报表比较多

 

3 > sql FIND_IN_SET 的使用

 

很多时候我们在设计数据库表的时候 比如这个商品可能是 新品 热销 推荐 之类的 而存取的格式是 type(1,2,3),如果有件产品它又是新品又是热销 那我们要如何去写这条

SQL语句呢。在这个时候就是 FIND_IN_SET 函数出场的时候了。在手册中 这个函数

FIND_IN_SET(str,strlist)

假如字符串str 在由N 子链组成的字符串列表strlist 中, 则返回值的范围在 1 到 N 之间 。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串。

如果第一个参数是一个常数字符串,而第二个是type SET列,则   FIND_IN_SET() 函数被优化,使用比特计算。如果str不在strlist 或strlist 为空字符串,则返回值为 0 。

如任意一个参数为NULL,则返回值为NULL。 这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。

比如 SELECT FIND_IN_SET('1','0,1,2,3')  这样就会返回一个2了

 

完整的用法 select * from goods where fing_in_set('1',type) 这里的type指的是表字段

 

 

 

 4 > update 更新两张表之间的数据

 

UPDATE web_members_base,web_pc
SET web_members_base.mainimg=web_pc.url
WHERE web_pc.t=web_members_base.uid

 

 5 > sql替换字段里面的值

update 表名 set 替换字段=(REPLACE(替换字段,'原内容','新内容'))

 

把字段·subject· 里情缘全部替换成尘缘

UPDATE web_mail_queue SET SUBJECT=(REPLACE(SUBJECT,'情缘','尘缘'))

 

6 > domain 有重复值 删除值保留一个

delete from juyu_domain_deal where deal_id not in
(select min(c.deal_id) as recordid from (select * from juyu_domain_deal ) c group by domain );

 
 
 
posted @ 2012-09-29 14:18  Sudo高  阅读(326)  评论(0编辑  收藏  举报