неопределенный метод `gsub’ для nil: NilClass или как использовать метод gsub в rails

#mysql #ruby-on-rails #ruby #ruby-on-rails-3

#mysql #ruby-on-rails #ruby #ruby-on-rails-3

Вопрос:

Я хочу последовательно генерировать Employee_ID с, я исправил начальный идентификатор сотрудника в таблице базы данных. формат «E36162000», я беру последний идентификатор сотрудника из таблицы, затем извлекаю только целочисленное значение, затем добавляю единицу, это будет следующим employee id .

Но в этом методе gsub() не работает, метод gsub извлекает целое число идеально, ссылка Следующая Employee_id = E36162001

Но когда я отправляю, появляется ошибка. Я отправляю код и сортирую экран, пожалуйста, помогите мне

_employee_details.html.erb — это мое мнение

 <div class="modal-body">
    <h2 class="text-center">Add <span>Employee Details</span></h2>
    <div class="post-new-job head-border">
      <div class="alert alert-success" role="alert" id='success-job' style='display:none;'>Employee Details is successfully added.</div>
        <div class="form-body">             
            <%= form_for(:employee_details, :url => {:controller => 'hr', :action => 'create'}) do |f| %>                   
                <div class="col-md-12">
                <!--auto generate emp id-->
                <% @last_emp_id = EmployeeDetail.select("employee_id").last %>
                <% emp_id = @last_emp_id.employee_id  %>
                <% emp_id_sub = emp_id.gsub(/[^d]/, '') %>
                <% auto_generate_id = 'E'.to_s   (emp_id_sub.to_i   1).to_s %>
                <h1> Employee ID : <%= auto_generate_id %> </h1>

            
                <div class="mydata">
                 <%= f.hidden_field :offer_letter_id, { class: 'form-control', id: 'recipient-name' } %>
                </div>
            
                 <div class="form-group">
                    <label class="control-label">Employee ID</label>
                    <div class="input-group"> <span class="input-group-addon"> <i class="fa fa-user"></i> </span>
                      <%= f.text_field :employee_id, { :value => auto_generate_id, :disabled=>true , :required => true, placeholder: 'E12345678', class: 'form-control' } %>
                    </div>
                  </div>

                  <div class="form-group">
                    <label class="control-label">Bank Account</label>
                    <div class="input-group"> <span class="input-group-addon"> <i class="fa fa-university"></i> </span>
                      <%= f.text_field :bank_ac, {placeholder: '06464060852634865', class: 'form-control' } %>
                    </div>
                  </div>

                  <div class="form-group">
                    <label class="control-label">Bank IFSC Code</label>
                    <div class="input-group"> <span class="input-group-addon"> <i class="fa fa-code"></i> </span>
                      <%= f.text_field :bank_ifsc, {placeholder: 'SBI012356', class: 'form-control' } %>
                    </div>
                  </div>

                  <div class="form-group">
                    <label class="control-label">End of Date</label>
                    <div class="input-group"> <span class="input-group-addon"> <i class="fa fa-calendar"></i> </span>
                      <%= f.text_field :work_end_date, {  placeholder: 'MM/DD/YYYY', id: 'datepicker', class:"datepicker_style" } %>
                    </div>
                  </div>

                  <div class="form-group">
                    <label class="control-label">Gender</label>
                    <div class="input-group"> <span class="input-group-addon"> <i class="fa fa-male fa-female"></i> </span>
                      <%= f.select :gender, ['Male', 'Female'], { }, class: "form-control" %>
                    </div> 
                  </div>

                  <div class="form-group">
                    <label class="control-label">Spouse Name</label>
                    <div class="input-group"> <span class="input-group-addon"> <i class="fa fa-user"></i> </span>
                      <%= f.text_field :spouse_name, { placeholder: 'Father/Mother/Wife name', class: "form-control" } %>
                    </div>
                  </div> <br>

                  <div class="form-group">
                    <a><%= f.submit "Add Employee Details", :class => "btn btn-primary" %></a> 
                  </div>
                </div>
                <div class="col-md-2"></div>                
            <%- end -%>
        </div>      
    </div>
   </div>
  

employee_details.rb — это моя модель

 class EmployeeDetail < ActiveRecord::Base
   belongs_to :user
   validates :offer_letter_id, presence: true 
end
  

hr_controller.rb — это мой контроллер

 class HrController < ApplicationController
def new
    @employees = EmployeeDetail.new
end

# edit employee information
def edit
    @employees = EmployeeDetail.find(params[:id])
end
    
def create
    @employees = EmployeeDetail.new(employee_params)
    if @employees.save
        redirect_to :action => 'internal_employee_page'
    else
        redirect_to :action => 'internal_employee_page'
    end
end

def show
    @employees = EmployeeDetail.find(params[:id])
end

def update
    @employees = EmployeeDetail.find(params[:id])

    if @employees.update(employee_params)
        redirect_to :action => 'internal_employee_page'
    else
        redirect_to :action => 'internal_employee_page'
    end
end

private

    def employee_params
         params.require(:employee_details).permit(:offer_letter_id, :employee_id, :bank_ac, :bank_ifsc, :spouse_name, :gender, :work_end_date)
    end     
 end
  

мой вид макета
введите описание изображения здесь

** Ошибка в этой строке **

<% emp_id_sub = emp_id.gsub(/[^d]/, '') %>

ошибка
введите описание изображения здесь

Когда я нажимаю на кнопку отправки, генерируется ошибка, но данные сохраняются в таблице employee_details, за исключением Employee_Id

Ответ №1:

Возможно, у вас нет emp_id . Попробуйте изменить код на,

 <% @last_emp_id = EmployeeDetail.select("employee_id").last %>
<% emp_id = @last_emp_id.employee_id  %>
<% emp_id_sub = emp_id.present? ? emp_id.gsub(/[^d]/, '') : ''%>
<% auto_generate_id = emp_id_sub.length > 0 ? ? ('E'.to_s   (emp_id_sub.to_i   1).to_s) : "" %>
<h1> Employee ID : <%= auto_generate_id %> </h1>
  

проверка наличия emp_id и затем emp_id_sub

Обновление: Добавлен пример запроса с использованием select согласно комментарию @mudasobwa

 2.3.1 :015 > @user = User.select("email").last
  User Load (0.5ms)  SELECT  `users`.`email` FROM `users`  ORDER BY `users`.`id` DESC LIMIT 1

 => #<User id: nil, email: "test@ead.com"> 

2.3.1 :016 > email = @user.email
 => "test@ead.com" 
  

Комментарии:

1. кто сказал, что I равно нулю, я попробовал это в своем коде, а затем только опубликовал свой ответ.

2. Должен ли я вставить свой запрос в вопрос?

3. @mudasobwa, пожалуйста, проверьте пример запроса, используя select в моем ответе.

4. нет проблем, вы старший, сэр, мы будем уважать ваши предложения, пожалуйста, проверьте или сообщите один раз, прежде чем отклонять его. в любом случае, это происходит, сэр. 🙂

Ответ №2:

Мы также можем создать метод в модели и вызывать before_save всякий раз, когда создаем новые данные сотрудника, тогда перед сохранением он будет выполнен и сохранит идентификатор сотрудника в базе данных

 class EmployeeDetail < ActiveRecord::Base
belongs_to :user
validates :offer_letter_id, presence: true
# auto generate employee id
before_save :Auto_generate_emp_id

def Auto_generate_emp_id
    @last_emp_id = EmployeeDetail.order("employee_id").last 
    emp_id = @last_emp_id.employee_id
    emp_id_sub = emp_id.gsub(/[^d]/, '')
    auto_generate_id = 'E'.to_s   (emp_id_sub.to_i   1).to_s 
    self.employee_id = auto_generate_id
end
  

конец