初学rails项目总结(四)

这次是需要写一个接口,用来传递数据,其他用户使用我们系统的时候有一些部门我们表里是不存在的,people表和department表是有关联,所以第一个是传递过来的数据进行整理,然后把不存在的部门插入到表中.

  skip_before_filter :check_if_login_required //跳过用户验证
  before_filter :set_app_user  #使用token进行用户验证
@err_mess = []
    niu_department = params[:totle].to_s.split("-")[0]
    niu_center = params[:totle].to_s.split("-")[1]
    niu_office_location = params[:totle].to_s.split("-")[2]
    current_system_id = Irm::ExternalSystem.current_system.id
    source_system_id = Irm::ExternalSystem.current_system.id

这是对传过来的参数进行处理,如”蒙牛-财务-西安”,需要用分隔符取出来

if !Niu::OrganizationalStructure.find_by(organizational_structure_code:params[:niu_department_id]).present?
      begin
        ActiveRecord::Base.transaction do
          department = Niu::OrganizationalStructure.new(:organizational_structure_code => params[:niu_department_id],
                                                        :organizational_structure_type => "department",
                                                        :description => niu_department, 
                                                        :current_system_id => current_system_id,
                                                        :source_system_id => source_system_id )
        end
      rescue => e
        err_mess << ["#{department.errors.to_a}"]
      end
    end

先判断这个部门id存在不存在,如果不存在,则进行new操作,部门的就是这样
员工则需要判断这个员工是否存在,不存在则创建,存在则进行更新

@err_mess = []
    if params[:login_name].present?
      if Irm::Person.find_by(login_name:params[:login_name]).present?
        person = Irm::Person.find_by(login_name:params[:login_name])
        update_attributes_hash = {}
        update_attributes_hash[:first_name] = params[:first_name] if params[:first_name].present?
        update_attributes_hash[:email_address] = params[:email_address] if params[:email_address].present?
        ``````
        if !person.update_attributes(update_attributes_hash)
          @err_mess << ["#{person.errors.to_a}"]
        end
      end

这个是更新,如果不存在,需要创建,跟创建部门类似

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值