0 0

Rails3 ActiveRecord 如何删除有重复字段的数据库记录?10

比如有个users表,email字段应该是唯一的,activerecord要怎样写,可以删除掉email字段发生重复的记录?

问题补充:
tiroc 写道
不太明白你是问数据库中已经存在email重复的用户,准备删除掉。还是问如何设置才能避免这种情况?
猜你是想问如何设置,要先在model中设置
class User < ActiveRecord::Base
  ...
  validates :email, :uniqueness => true
  ...
end

然后在数据库迁移中添加唯一约束
add_index :users, :email, :unique => true

这样的话,已存在的email就无法再次创建用户了。

谢谢!
unique我是知道的。
其实这个问题是我看到的一道面试题。
我们可以假设是这种情况
数据库并不是rails的migrate出来的,而是某个历史系统的用户数据库,里面的email并不是唯一的
在这种情况下删除email重复的记录
2011年6月23日 12:57

3个答案 按时间排序 按投票排序

0 0

如果没有限定重复的记录删除哪一个的话,就一个记录一个记录的找,然后删除相同的。
也应该可以用find(:all,:group=>'email'),先按email把记录分组,再遍历每个组里找第一条记录,组成新的表,覆盖掉原表,这样感觉好像效率高点?

2011年7月04日 16:09
0 0

这我就不晓得出题人想考察什么了,我做的话就直接查出相关的记录,删掉就行了。

2011年6月27日 11:28
0 0

不太明白你是问数据库中已经存在email重复的用户,准备删除掉。还是问如何设置才能避免这种情况?
猜你是想问如何设置,要先在model中设置

class User < ActiveRecord::Base
  ...
  validates :email, :uniqueness => true
  ...
end

然后在数据库迁移中添加唯一约束
add_index :users, :email, :unique => true

这样的话,已存在的email就无法再次创建用户了。

2011年6月23日 15:18

相关推荐

    Pro ActiveRecord Databases with Ruby and Rails.pdf

    《Pro ActiveRecord Databases with Ruby and Rails》这本书深入探讨了如何使用ActiveRecord框架来高效地处理Ruby on Rails中的数据库操作。本书由Kevin Marshall、Chad Pytel和Jon Yurek共同撰写,他们都是在Ruby与...

    Ruby on rails 数据库详细配置

    配置完成后,Rails应用程序将能够根据这些参数与数据库建立连接,并执行CRUD(创建、读取、更新、删除)操作。Rails的ActiveRecord库提供了方便的数据模型抽象,使得开发者可以使用Ruby代码轻松操作数据库表。 总的...

    Apress Pro ActiveRecord Databases with Ruby and Rails.pdf

    **ActiveRecord**是Ruby on Rails框架中的核心组件之一,它实现了ORM的概念,允许开发者以面向对象的方式处理数据库记录。通过ActiveRecord,开发者可以轻松地创建、读取、更新和删除数据库中的数据,而无需编写复杂...

    model-formatter:允许您轻松处理 Rails ActiveRecord 中的字段,这些字段在设置或从数据库中检索时需要格式化或去除格式

    ModelFormatter 模块允许您在设置或从数据库中检索时轻松处理需要格式化或去除格式的字段。 您可以将一个或多个列指定为“格式化列”,如下例所示: class Widget &lt; ActiveRecord xss=removed&gt; :integer # ...

    Ruby-ActiveRecord插件允许你隐藏和恢复记录没有真正删除它们

    当一条记录被“删除”时,它不会立即从数据库中物理删除,而是通过添加一个时间戳字段(例如`deleted_at`)并更新该字段的值来标记这条记录为已删除。这样,即使记录被“删除”,也能在需要时通过特定的查询条件找回...

    Castle ActiveRecord快速入门指南、ActiveRecord帮助文档

    这个框架借鉴了 Ruby on Rails 中的 ActiveRecord 模式,将业务对象与数据库记录关联起来,使得开发者可以更专注于编写业务逻辑,而不是数据库访问代码。本指南将深入探讨 Castle ActiveRecord 的核心概念、安装、...

    ruby on rails 3.1.0数据库查询方法汇总

    ### Ruby on Rails 3.1.0 数据库查询方法汇总 #### 一、基础操作 在 Ruby on Rails 3.1.0 中,对于数据库的操作非常便捷,主要包括数据的保存、创建、查找等功能。 1. **保存数据**: - `a = Category.new(:name...

    Ruby on Rails中的ActiveRecord编程指南

    在Ruby on Rails框架中,ActiveRecord是一种用于实现数据库抽象层的对象关系映射(ORM)工具。它为开发人员提供了一种简单而强大的方式来处理数据库记录。本文档旨在为开发者提供一系列关于如何高效、规范地使用...

    Rails项目源代码

    Rails使用ActiveRecord作为ORM,它使得Ruby类可以直接与数据库表进行交互。在这个项目中,`User`和`Image`模型可能会与数据库中的相应表关联,通过定义属性和关系,如`has_many :images`表示一个用户可以拥有多个...

    castle ActiveRecord 源代码

    ActiveRecord模式源于Ruby on Rails,其核心思想是将数据库表与业务对象绑定,每个对象都代表一个数据库记录,并且包含操作这些记录的方法。这种模式简化了数据访问逻辑,使得开发者可以专注于业务逻辑的实现。 在...

    ActiveRecord简单实例代码.zip

    ActiveRecord是Ruby on Rails框架中的一个核心组件,它实现了对象关系映射(ORM)系统,使得开发者能够以面向对象的方式处理数据库操作。在这个压缩包"ActiveRecord简单实例代码.zip"中,我们预计会找到一些使用...

    C# Castle.ActiveRecord CS源码示例教程.zip

    ActiveRecord 是一种设计模式,源自 Ruby on Rails,它将业务对象与数据库记录关联起来,使得开发者可以直接操作对象,而无需编写大量的 SQL 语句。Castle.ActiveRecord 将这种理念带到了 .NET 平台,通过注解或者...

    Java敏捷持久层-ROR-ActiveRecord持久层框架的Java实现

    在Java世界里,虽然Hibernate和JPA等框架已经非常成熟,但Ruby on Rails(ROR)中的ActiveRecord模式也受到了不少Java开发者的青睐,并有了一些移植到Java平台的实现。 ActiveRecord是一种对象关系映射(ORM)模式...

    Ruby-MongoModel针对MongoDB的RubyORM框架兼容Rails3

    6. **继承支持**:与ActiveRecord类似,MongoModel支持单继承,一个父类可以有多个子类,子类会继承父类的字段和方法。 7. **关联**:尽管MongoDB不像关系型数据库那样强调关系,但MongoModel还是提供了基本的关联...

    Rails for Zombies

    通过"Rails for Zombies"教程,学习者能够对Ruby on Rails框架中的基本概念、数据结构、数据库操作方法、对象属性的访问方式等有一个全面而深入的理解,并能够运用这些知识点来创建基本的Web应用程序。

    应用Rails进行敏捷Web开发中文第三版

    2. **数据库迁移**:了解如何使用ActiveRecord的迁移工具(Migration)来修改数据库结构,如添加、删除或修改字段。 3. **路由**:Rails的路由系统如何将URL映射到特定的控制器和动作,以及如何自定义路由规则。 4...

    Ruby-Annotate注释Rails类模式和路由信息

    **Rails类模式** 在Rails中指的是ActiveRecord模型,它们代表数据库中的表。通过注释模型,你可以快速查看每个模型字段的详细信息,包括其数据类型、是否为主键、是否自动递增等。这对于调试和优化数据库查询非常有...

    在Ruby on Rails中优化ActiveRecord的方法

    4. **缓存查询**:对于重复的、计算密集型或数据库密集型的查询,可以考虑使用ActiveRecord的`cache`或Rails的全局缓存机制来存储结果,减少不必要的数据库访问。 5. **避免在循环中执行数据库操作**:在循环中执行...

    Rails实现字段加密存储

    存储前,加密后再存储到数据库 读取后,利用 KEY 进行解密 实现 ActiveSupport::MessageEncryptor 是 Rails 基于 openssl 封装实现的一个类,可用于对一个对象进行加密、解密操作。例如: salt = SecureRandom....

    Ruby on Rails 指南 v5.0.1 中文版

    **:ActiveRecord是Rails中的ORM(对象关系映射)组件,它允许开发者以面向对象的方式操作数据库。 - **ActiveRecord中的"多约定少配置"原则**:解释这一原则是如何减少开发者的工作量,并提高开发效率的。 - **创建...

Global site tag (gtag.js) - Google Analytics