中国唯一一家专业只做ARACLE认证和BDA实训的甲骨文金牌合作企业

网络授课

技术沙龙

MySQL培训教程:删除数据命令

MySQL培训教程:删除数据命令,可以使用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在关闭会话或对变量重新赋值以前,可以一直使用用户自定义变量。

CUUG 优技培训

中国Oracle培训领航专家

CUUG -CHINA UNIX USER GROUP,是国际UNIX组织UNIFORUM的中国代表,是国内悠久的专业UNIX培训机构,被誉为中国UNIX 的摇篮。

金牌讲师

行业资深实战专家 让学习就像在就业
展开

实操环境

让每一个DBA课程学员有真正的实操练习

让每一个DBA课程学员有真正的实操练习

让每一个DBA课程学员有真正的实操练习

让每一个DBA课程学员有真正的实操练习

院校合作

学校新闻

行业新闻

在线预约 抢先报名 获取课程排期

请输入您的手机号

申请试听
版权所有:北京神脑资讯科技有限公司
地址:北京市海淀区紫竹花园4号楼D座703
全国免费咨询电话:400-0909-964
电话:010-59426307 ,邮政编码:100089
E-mail:cuug_bj@cuug.com
拨打电话
在线咨询
首页