仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1012|回复: 8
打印 上一主题 下一主题

[学习教程] MYSQL编程:删除数据库中反复数据的几个办法

[复制链接]
活着的死人 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 22:36:27 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
对免费版的用户也具有充足的支持服务。在dev.mysql.com上,一个大型的MySQL学习教程强大社区用户和开发者可以讨论所有关于MySQL的事情。这个站点拥有博客、指南、视频、技术交流会、白皮书和论坛等方式的交流。数据|数据库|反复办法一
declare@maxinteger,@idinteger
declarecur_rowscursorlocalforselect主字段,count(*)from表名groupby主字段havingcount(*)>1
opencur_rows
fetchcur_rowsinto@id,@max
while@@fetch_status=0
begin
select@max=@max-1
setrowcount@max
deletefrom表名where主字段=@id
fetchcur_rowsinto@id,@max
end
closecur_rows
setrowcount0
办法二
有两个意义上的反复纪录,一是完整反复的纪录,也即一切字段均反复的纪录,二是部分关头字段反复的纪录,好比Name字段反复,而其他字段纷歧定反复或都反复能够疏忽。
1、关于第一种反复,对照简单办理,利用
selectdistinct*fromtableName
就能够失掉无反复纪录的了局集。
假如该表必要删除反复的纪录(反复纪录保存1条),能够按以下办法删除
selectdistinct*into#TmpfromtableName
droptabletableName
select*intotableNamefrom#Tmp
droptable#Tmp
产生这类反复的缘故原由是表计划不周发生的,增添独一索引列便可办理。
2、这类反复成绩一般请求保存反复纪录中的第一笔记录,操纵办法以下
假定有反复的字段为Name,Address,请求失掉这两个字段独一的了局集
selectidentity(int,1,1)asautoID,*into#TmpfromtableName
selectmin(autoID)asautoIDinto#Tmp2from#TmpgroupbyName,autoID
select*from#TmpwhereautoIDin(selectautoIDfrom#tmp2)
最初一个select即失掉了Name,Address不反复的了局集(但多了一个autoID字段,实践写时能够写在select子句中省往此列)
DBaaS系统本身并不提供面对面访问或个人客户关系或持续不断的支持MySQL学习教程。这些就是需要解决方案提供商的原因。他们帮助客户选择正确的解决方案、规划集成和迁移战略,然后协助实施。
老尸 该用户已被删除
沙发
发表于 2015-1-19 18:16:25 | 只看该作者
个人感觉没有case直观。而且默认的第三字段(还可能更多)作为groupby字段很容易造成新手的错误。
若相依 该用户已被删除
板凳
发表于 2015-1-27 20:16:01 | 只看该作者
可以动态传入参数,省却了动态SQL的拼写。
灵魂腐蚀 该用户已被删除
地板
发表于 2015-2-5 11:14:34 | 只看该作者
习惯敲命令行的朋友可能会爽一些。但是功能有限。适合机器跑不动SQLServerManagementStudio的朋友使用。
第二个灵魂 该用户已被删除
5#
发表于 2015-2-11 11:34:48 | 只看该作者
光写几个SQL实在叫无知。
乐观 该用户已被删除
6#
发表于 2015-3-2 12:12:07 | 只看该作者
这就引发了对varchar和char效率讨论的老问题。到底如何分配varchar的数据,是否会出现大规模的碎片?
谁可相欹 该用户已被删除
7#
发表于 2015-3-11 03:41:38 | 只看该作者
SQLServer的异构移植功能个人感觉最好了。(如果对比过SQLServer的链接服务器和Oracle的透明网关的朋友会发现SQLServer的sp_addlinkedserver(openquery)异构数据库系列比Oracle真是强太多了。)
飘灵儿 该用户已被删除
8#
发表于 2015-3-17 20:09:30 | 只看该作者
比如,MicrosoftSQLServer2008的某一个版本可以满足现在的这个业务的需要,而且价格还比Oracle11g要便宜,那么这一产品就是适合的。
莫相离 该用户已被删除
9#
发表于 2015-3-24 23:37:08 | 只看该作者
索引视图2k就有。但是2005对其效率作了一些改进但是schema.viewname的作用域真是太限制了它的应用面。还有一大堆的环境参数和种种限制都让人对它有点却步。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-12-29 23:03

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表