免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3776 | 回复: 11
打印 上一主题 下一主题

执行语句出错 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-10-29 14:26 |只看该作者 |倒序浏览
表内容大致是这样:

--------ip----------------starttime  -----------endtime-------------count
192.168.1.11            12:12:12               14:14:14                 1
192.168.1.12            12:12:12               14:14:14                 1
192.168.1.11            12:12:12               14:14:14                 1
192.168.1.14            12:12:12               14:14:14                 1

现在要把每列中count的值改成相应的IP出现的次数,此例中应改为:
--------ip----------------starttime  -----------endtime-------------count
192.168.1.11            12:12:12               14:14:14                 2
192.168.1.12            12:12:12               14:14:14                 1
192.168.1.11            12:12:12               14:14:14                 2
192.168.1.14            12:12:12               14:14:14                 1

我写的语句是

update mytable set count=(select count(*) from mytable where ip='192.168.1.11') where ip='192.168.1.11';
但是报错,You can't specify target table for update in FROM clause
网上说不能在同一个表中查询,之后再修改这个表,那么该怎么写呢?

而且我这条语句只修改ip为192.168.1.11的行,我要把所有行都改了,该怎么写呢?

谢谢各位了。

论坛徽章:
0
2 [报告]
发表于 2010-10-29 15:02 |只看该作者
本帖最后由 飞鸿无痕 于 2010-10-29 20:00 编辑

回复 1# Dxx_守护精灵


有个笨办法可以
要借助以一个临时表:
create table mytable_temp like mytable;
insert into mytable_temp (select ip,starttime,endtime,count(*) from mytable group by ip);
update mytable set count=(select count from mytable_temp  where mytable.ip=mytable_temp.ip);
drop table mytable_temp;

用这个就不用另外建表了,呵呵,参考6楼兄弟的!
UPDATE mytable t, (SELECT ip, COUNT(*) count FROM mytable GROUP BY ip) c SET t.count=c.count WHERE  t.ip=c.ip;
乱写的,等高手的答案!

论坛徽章:
0
3 [报告]
发表于 2010-10-29 16:10 |只看该作者
回复 2# 飞鸿无痕


    谢谢了,但是你这个执行时间太长了啊。

论坛徽章:
0
4 [报告]
发表于 2010-10-29 16:16 |只看该作者
回复 3# Dxx_守护精灵

有多少万条记录呢?

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
5 [报告]
发表于 2010-10-29 16:17 |只看该作者
IP上面加索引试试吧,这个应该不慢的

论坛徽章:
0
6 [报告]
发表于 2010-10-29 16:53 |只看该作者
试试这个

  1. UPDATE mytable t, (SELECT ip, COUNT(*) count FROM mytable) c
  2. SET t.count=c.count
  3. WHERE 1=1
  4.     AND t.ip=c.ip
  5. --    AND t.ip='A.B.C.D'
复制代码

论坛徽章:
0
7 [报告]
发表于 2010-10-29 17:05 |只看该作者
回复 4# 飞鸿无痕


    日志有1亿1千万行,很多很多,每天都有上亿条。

论坛徽章:
0
8 [报告]
发表于 2010-10-29 17:06 |只看该作者
回复 6# lovetide


    现在只能对A.B.C.D这个IP做操作,如果我要对表里出现的所有IP都做同样的操作呢?

(愁死,做linux的,根本不懂数据库,老大还让我做。)

论坛徽章:
0
9 [报告]
发表于 2010-10-29 17:12 |只看该作者
回复 7# Dxx_守护精灵


    加上索引看看要执行多长时间,哈哈,正式锻炼你的好机会了!

论坛徽章:
0
10 [报告]
发表于 2010-10-29 17:13 |只看该作者
回复  lovetide


    现在只能对A.B.C.D这个IP做操作,如果我要对表里出现的所有IP都做同样的操作呢? ...
Dxx_守护精灵 发表于 2010-10-29 17:06



    就是对所有数据进行更新,除非你加上最后面那 1 行之后才是只针对单个 IP 进行更新的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP