Warning: Unexpected character in input: ' in D:\php186\www.php186.com\index.php on line 38
 mysql使用REPLACE必须同时拥有表的INSERT和DELETE权限-WEB开发网
您的位置:网站主页> Mysql教程 > mysql使用REPLACE必须同时拥有表的INSERT和DELETE权限

mysql使用REPLACE必须同时拥有表的INSERT和DELETE权限

时间:2015-04-15 10:57:35   编辑:王连龙   文章来源:php教学网 已阅读:2677 次

  mysql使用REPLACE必须同时拥有表的INSERT和DELETE权限

 

       REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。请参见13.2.4节,“INSERT语法”。

  注意,除非表有一个PRIMARY KEY或UNIQUE索引,否则,使用一个REPLACE语句没有意义。该语句会与INSERT相同,因为没有索引被用于确定是否新行复制了其它的行。

  所有列的值均取自在REPLACE语句中被指定的值。所有缺失的列被设置为各自的默认值,这和INSERT一样。您不能从当前行中引用值,也不能在新行中使用值。如果您使用一个例如“SET col_name = col_name + 1”的赋值,则对位于右侧的列名称的引用会被作为DEFAULT(col_name)处理。因此,该赋值相当于SET col_name = DEFAULT(col_name) + 1。

  MySQL Replace INTO权限

  为了能够使用REPLACE,您必须同时拥有表的INSERT和DELETE权限。

 

  REPLACE语句会返回一个数,来指示受影响的行的数目。该数是被删除和被插入的行数的和。如果对于一个单行REPLACE该数为1,则一行被插入,同时没有行被删除。如果该数大于1,则在新行被插入前,有一个或多个旧行被删除。如果表包含多个唯一索引,并且新行复制了在不同的唯一索引中的不同旧行的值,则有可能是一个单一行替换了多个旧行。

  受影响的行数可以容易地确定是否REPLACE只添加了一行,或者是否REPLACE也替换了其它行:检查该数是否为1(添加)或更大(替换)。

  如果您正在使用C API,则可以使用mysql_affected_rows()函数获得受影响的行数。

  目前,您不能在一个子查询中,向一个表中更换,同时从同一个表中选择。

 

  以下是所用算法的更详细的说明(该算法也用于LOAD DATA…REPLACE):

 

  1. 尝试把新行插入到表中

  2. 当因为对于主键或唯一关键字出现重复关键字错误而造成插入失败时:

  a. 从表中删除含有重复关键字值的冲突行

  b. 再次尝试把新行插入到表中

 

  MySQL Replace INTO格式

 

  REPLACE [LOW_PRIORITY | DELAYED]

  [INTO] tbl_name [(col_name,...)]

  VALUES ({expr | DEFAULT},…),(…),…

  或:

  REPLACE [LOW_PRIORITY | DELAYED]

  [INTO] tbl_name

  SET col_name={expr | DEFAULT}, …

  或:

  REPLACE [LOW_PRIORITY | DELAYED]

  [INTO] tbl_name [(col_name,...)]

  SELECT …

本文地址:http://www.php186.com/content/article/mysql/24842.html(转载请保留)

相关关键词搜索:mysql使用REPLACE必须同时拥有表的INSERT和DELETE权限

查看评论更多>>
4楼 liujian 2015-04-21 17:34发表
好网站,值得收藏,以后会多多来看,很多文章内容都挺好的!
3楼 niulang 2015-04-21 17:33发表
不论国外,单是我们中国,各种各样的网站数不胜数。打开页面第一个看到的不是你的网站有什么,而是你的整体布局,一个清爽、干净、整洁的页面是一个赢得人心的法宝,大站有大站的气势,小站有小站的风格,好的视觉效果可以告诉人们这个站点有实力,这个站点值得信赖,给人很强的亲和力,有一种发现新宝地,希望赶紧收藏的冲动。
2楼 leenons 2015-04-21 17:28发表
现在看php学习网都会在百度上面找找看评分怎么样,值不值得一看;同时也会将看过的php教程网站记录,有时候留下一些自己的感想的评论,有很多逗比的评论,还有很多专业的评论,建议大家可以在web开发网上面寻找相关文章、api,大部分的内容都还合理。
1楼 xiaobudian 2015-04-21 17:25发表
网站文章挺不错的,值得学习,希望站长多多努力!
发表评论
      
* 以上用户言论只代表其个人观点,不代表www.php186.com网站的观点或立场
推荐文档更多

WEB开发网 | PHP教程 | Mysql教程 | Apache教程 | 最新文章 | PHP面试题| 网站地图 | Google地图 | Baidu地图 | 在线WEB论坛| 中纪委反腐最新消息

WEB技术QQ交流群:151888886 站长Q号:547218888
版权所有者:WEB开发网 地址:云南省文山州砚山县盘龙乡 滇ICP备12002707号-1
特别声明:本站内容仅供参考,不作为设计及确切依据!想了解更多,可立即进入Bbs提问