当前位置: Oracle DBA培训网-优技培训 >> MySQL培训 > MySQL培训教程 >

MySQL基础教程:删除数据delete语句

MySQL基础教程:删除数据delete语句

MySQL基础教程:删除数据delete语句,可以使用DELETE语句删除指定的数据行。例如,因为我们已决定不再出售《HarryPotter》(哈里波特)的系列作品,于是从books表中删除了作者为J.K.Rowling的所有图书记录,我们可以输入下列语句完成这项工作:

  1. DELETE FROM books   
  2. WHERE author_id =   
  3. (SELECT authors.author_id FROM authors   
  4. WHERE author_last = 'Rowling'   
  5. AND author_?rst = 'J. K.');   
  6. DELETE FROM authors  
  7. WHERE author_last = 'Rowling' 
  8. AND author_?rst = 'J. K.'

在这里,我们仅从books表中删除了一行记录,该行的作者标识码为从authors表中获取的任意值,这个值基于指定的作者姓名。也就是说,author_id必须是由SELECT语句返回的任意值,圆括号中的是子查询语句。MySQL4.1版本或更新的版本支持语句中的子查询操作。如果你想使用早期的MySQL版本删除上面的数据,需要将圆括号中的SELECT语句单独执行(而不是作为子查询语句执行)来获取作者的标识码,然后再运行第一行的DELETE语句,在语句的结尾处将附加的SELECT语句手工替换成作者标识码。

你也可以使用用户自定义变量替换上面的SQL语句。下面是使用用户自定义变量的示例:

  1. SET @potter =   
  2. SELECT author_id FROM authors   
  3. WHERE author_last = 'Rowling'   
  4. AND author_?rst = 'J. K.');   
  5. DELETE FROM books  
  6. WHERE author_id = @potter;  
  7.  
  8. DELETE FROM authors  
  9. WHERE author_id = @potter; 

在第一部分,本书使用SET语句创建一个名为@potter的变量,并将括号中的SELECT语句作为值赋给此变量。顺便提及,尽管MySQL4.1以及以前的版本不支持子查询,但支持用户自定义变量。第二条SQL语句从books表中删除一行记录,该行的作者标识码与临时变量中的值相同。下面仍旧使用临时变量从authors表中删除数据。MySQL在关闭会话或对变量重新赋值以前,可以一直使用用户自定义变量。

技术沙龙MORE+

标签错误:<!-- #Label# labelId=20160707140604 moduleId=1 classId=12231768634 orderby=2 fields=url,title,u_info attribute= datatypeId=22192428132 recordCount=3 pageSize= <htmlTemplate><dt><img src="/images/index_26${index}.jpg" width="100" height="62" /><a href="$url" title="${title}">${title}</a><span>${api.left(u_info,60)}</span></dt></htmlTemplate> -->
我要参加技术沙龙