CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
英特尔®游戏设计大赛100美元现金周周送 专题改版:Java Web 专题
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  Oracle >  基础和管理

一个简单的问题?

楼主jsyx()2003-06-04 18:35:03 在 Oracle / 基础和管理 提问

有两个表      
  TEST1包含两个字段ID,NAME      
  TEST     一个字段NAME      
     
  这样的SQL为什么不能执行?      
  DELETE     TEST     WHERE     TEST.NAME=TEST1.NAME      
     
  为什么必须要这样才行?      
  DELETE     TEST     WHERE     TEST.NAME     IN     (SELECT     TEST.NAME     FROM     TEST,TEST1     WHERE     TEST.NAME=TEST1.NAME)      
  问题点数:100、回复次数:6Top

1 楼icewhite(默涵)回复于 2003-06-04 19:08:33 得分 0

语法,规则罢了!Top

2 楼jljlwsy()回复于 2003-06-04 20:26:48 得分 0

规则Top

3 楼llm06(blacksheep)回复于 2003-06-04 20:40:47 得分 50

delete   from   test   where   test.name   in   (select   name   from   test1)  
   
  WHERE     TEST.NAME=TEST1.NAME     这个是用来做连接表查询用的  
  delete   时where子句必须是一种确定的逻辑关系Top

4 楼things(Loving You)回复于 2003-06-04 21:50:53 得分 0

同意llm06(blacksheep)    
   
  语法问题Top

5 楼BlueskyWide(谈趣者)回复于 2003-06-05 08:50:32 得分 50

“多对多”的变成“一对多”。  
  Top

6 楼shuipipi(水皮皮)回复于 2003-06-05 09:10:48 得分 0

delete   from   tab1   where   exist   (select   1   from   tab   where   tab1.id   =   tab.id);Top

相关问题

  • 简单!
  • 简单
  • 简单~~~
  • 简单
  • 简单!
  • 简单
  • 简单
  • 简单……
  • 简单问题不简单!
  • 简单的简单啊!

关键词

  • 字段
  • tab
  • test
  • 问题
  • delete
  • where
  • select

得分解答快速导航

  • 帖主:jsyx
  • llm06
  • BlueskyWide

相关链接

  • Oracle类图书

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
世纪乐知(北京)网络技术有限公司 版权所有, 京 ICP 证 020026 号
北京创新乐知广告有限公司 提供技术支持
Copyright © 2000-2007, CSDN.NET, All Rights Reserved
GongshangLogo