Skip to main content

ActiveRecord Attributes – access using Strings, Symbols and Direct Access rails

ActiveRecord Attributes – access using Strings, Symbols and Direct Access rails ?


Attributes can be accessed from ActiveRecord in various ways including symbolised, stringified or direct access. Each type of access has it’s own advantages and disadvantages as we will see in this tutorial.
Sample Table for use case -

Suppose we have a table users in database.
Table Name: users
id     name     city
1     Abcd     NewYork
2     Efgh     PolaAnd

Suppose, we want to have record of user with id = 21. Then we can get the details of this record using rails as,

user_details = User.where('id = 1').first

Now we will see different types of access over the active record user_details
1. Direct Access

Let us say we want to access name attribute of user from the ActiveRecord user_details. This can be obtained using direct access as follows,

name = user_details.name
puts "Name of the User is #{name}"
=> Abcd

By this way, direct access obtain value of attribute from ActiveRecord
2. Symbolised Access

Let us say we want to access name attribute of user from ActiveRecord user_details. This can be obtained using symbolised access as follows,

name = user_details[:name]
puts "Name of the User is #{name}"
=> Abcd

By this way, symbolised access obtain value of attribute from ActiveRecord
3. Stringified Access

Let us say we want to access name attribute of user from ActiveRecord user_details. This can be obtained using stringified access as follows,

name = user_details[‘name']
puts "Name of the User is #{name}"
=> Abcd

By this way, stringified access obtain value of attribute from ActiveRecord
How Direct Access is Faster?

Direct access is faster than symbolised or stringified access to get the value of attribute from ActiveRecord. Benchmarking the performance of Direct Access versus symbolised access versus stringified access is given below,

Benchmark.realtime do
    10000.times{p.id}
end
=> 0.006823

Benchmark.realtime do
    10000.times{p[:id]}
end
=> 0.015745

Benchmark.realtime do
    10000.times{p['id]'}
end
=> 0.017554

Above benchmarking clearly shows that Direct Access of attribute from ActiveRecord is much faster than the Symbolised or Stringified access.

Comments

Popular posts from this blog

Gem::LoadError (Specified 'mysql2' for database adapter, but the gem is not loaded. Add `gem 'mysql2'` to your Gemfile (and ensure its version is at the minimum required by ActiveRecord).?

Gem::LoadError (Specified 'mysql2' for database adapter, but the gem is not loaded. Add `gem 'mysql2'` to your Gemfile (and ensure its version is at the minimum required by ActiveRecord).) In rails?


1)change the gemfile in mysql version
 gem 'mysql2'

2)Change to mysql2 version
 gem 'mysql2','0.3.20'

Get user accessing ip address in rails?

Get user accessing ip address rails?

request.ip ->returns the ip, whether is is a local proxy ip (localhost address) or not.
*request.remote_ip -> is smarter and gets the ip address of the client outside of local proxies.
3)If you are using apache in front of a mongrel, then remote_ip will return the source address of the request, which in this case will be local host because the Apache web server is making the request, so instead put this in your controller:

@remote_ip = request.env["HTTP_X_FORWARDED_FOR"]

PayUMoney Integration in Ruby on Rails

PayUMoney Integration in Ruby on Rails


Generating Cheksum in Payu
   Hash or Checksum
= sha512(key|txnid|amount|productinfo|firstname|email|u
df1|udf2|udf3|udf4|udf5||||||salt)



Controller Code Will be
def payumoney
  @key = "gtKFFx"
  @salt =  "eCwWELxi"
  val = "#{key|txnid|amount|productinfo|firstname|email|u
df1|udf2|udf3|udf4|udf5||||||#{@salt}"
 @checksum = Digest::SHA512.hexdigest("#{val}")
end

<form action="https://test.payu.in/_payment" method='post' id='sub'  >
    <input type="hidden" name="key" value="<%=@key%>">
    <input type="hidden" name="hash" value="<%=@checksum%>">
    <input type="hidden" name="txnid" value="TXN1234">
    <input type="hidden" name="amount" value="200">
    <input type="hidden" name="firstname" value=&quo…