201705 Ruby基础拾遗
- Mixin
- override
- 异常处理
- super 与super()
- 使用%()处理需要string interpolation但同时也需要" "(double quote)的状况
- 当要宣告一个拥有多字串的Array 阵列时,偏好使用%w
- 大数据情况下
- 1. 尽量避免使用ActiveRecord Object
- 2. 有 update_all 可以用,少用 for / each
- 3.不要直接使用Post.all.each,可以用 find_in_batches
- 4. 批量修改数据记录时,使用transaction 跳过每次的 BEGIN COMMIT 过程
- 5.使用 update_column / sneacky-save 而非原生 save
- 6.可以的话使用 Post.select("column 1, colum2").where("id < 10"), 代替Post.where("id < 10")
- 7. 使用 delegate 把大字段搬出去,独立成表
- 8. 添加索引INDEX,避免索引过长
- 9. delete / destroy的时间成本
- 10. 无法避免的耗时操作丟到 background job 去操作。
- 结论:当数据量大到一定程序,请尽量使用原生sql
Mixin
- Mixin include: 作为实例方法引入
- extend : 作为类方法引入
- Inheritance(继承)
override
ruby class內的method都是可以被修改、添加定义的。
修改影响所有实例,包括修改操作前创建的实例。异常处理
begin
# 可能會發生例外的 code
rescue AExceptionClass => some_variable
# 屬於 AExceptionClass 的例外發生時 run 這段 code
rescue BExceptionClass => some_other_variable
# 屬於 BExceptionClass 的例外發生時 run 這段 code
else
# 都沒有例外發生時 run 這段 code
ensure
# 無論有沒有發生例外,都會 run 這段 code
end
def foo
# 正常時的處理
rescue
# 發生例外時的處理
end
super 与super()
- super:呼叫父类别的同名函式,并且将本函式的所有参数传入父类别的同名函式。
- super(): 带括号则表示呼叫父类别的同名函式,但是不传入任何参数。
使用%()处理需要string interpolation但同时也需要" "(double quote)的状况
<%= "<div class=\"name\"> #{name} </div>" %>
<%= "<div class='name'> #{name} </div>" %>
<%= %(<div class="name">#{name}</div>) %>当要宣告一个拥有多字串的Array 阵列时,偏好使用%w
array = ["A", "B", "C", "D"] array = %w(A B C D)
Rails
大数据情况下
1. 尽量避免使用ActiveRecord Object
ActiveRecor,rake task在大数据量下运行是非常慢的,应该直接使用sql语句进行数据操作
2. 有 update_all 可以用,少用 for / each
posts = Post.where(:board_id => 5)
post.each do |post|
post.board_id = 1
post.save
end
当数据量达到十万条时,一天也跑不完 Rails 提供了 update_all 可以用,相当于直接使用sql的效果
Post.update_all({:board_id => 1}, {:board_id => 5})
3.不要直接使用Post.all.each,可以用 find_in_batches
如果十万笔数据加载到内存,估计超过10G,程序可能直接闪退
Post.find_in_batches(:conditions => "board_id = 5", :batch_size => 1000) do |posts|
posts.each do |post|
post.board_id = 1
post.save
end
end
4. 批量修改数据记录时,使用transaction 跳过每次的 BEGIN COMMIT 过程
Post.find_in_batches(:conditions => "board_id = 5", :batch_size => 1000) do |posts|
Post.transaction do
posts.each do |post|
post.board_id = 1
post.save
end
end
end
5.使用 update_column / sneacky-save 而非原生 save
save 存储资料时,会调用一堆 validator 和 callbacks
update_column / sneacky-save会跳过,直接修改数据库字段,区别是update_column一次只能修改一个字段,后者可修改多个字段。6.可以的话使用 Post.select("column 1, colum2").where("id < 10"), 代替Post.where("id < 10")
7. 使用 delegate 把大字段搬出去,独立成表
class Post < ActiveRecord::Base
has_one :meta after_create :create_meta deleagte :content, :to => :meta
end
8. 添加索引INDEX,避免索引过长
避免直接对varchar(255) 加索引
ALTER TABLE post DROP INDEX PTitle, ADD INDEX(PTitle(13));9. delete / destroy的时间成本
- destroy 刪除资料并callbacks
- delete 刪除资料,不callbacks
- destroy_all 和 delete_all 也类似
Mysql提供TRUNCATE TABLE清空表
delete_all不触发callback,但是会update index,所以相比TRUNCATE TABLE会很慢
TRUNCATE TABLE
ActiveRecord::Base.connection.execute("TRUNCATE TABLE #{table_name}")
10. 无法避免的耗时操作丟到 background job 去操作。
- delayed_job (不推荐)
- resque
- sidekiq
结论:当数据量大到一定程序,请尽量使用原生sql
201705 Ruby基础拾遗的更多相关文章
- 基础拾遗------redis详解
基础拾遗 基础拾遗------特性详解 基础拾遗------webservice详解 基础拾遗------redis详解 基础拾遗------反射详解 基础拾遗------委托详解 基础拾遗----- ...
- 基础拾遗------webservice详解
基础拾遗 基础拾遗------特性详解 基础拾遗------webservice详解 基础拾遗------redis详解 基础拾遗------反射详解 基础拾遗------委托详解 基础拾遗----- ...
- 基础拾遗-----mongoDB操作
基础拾遗 基础拾遗------特性详解 基础拾遗------webservice详解 基础拾遗------redis详解 基础拾遗------反射详解 基础拾遗------委托详解 基础拾遗----- ...
- 基础拾遗----RabbitMQ(含封装类库源码)
基础拾遗 基础拾遗------特性详解 基础拾遗------webservice详解 基础拾遗------redis详解 基础拾遗------反射详解 基础拾遗------委托详解 基础拾遗----- ...
- Ruby基础教程
一.Ruby基础知识 1.关于Ruby Ruby是脚本语言 Ruby是面向对象语言 Ruby是跨平台语言 Ruby是开放源码软件 2.Ruby入门书籍推荐 <Ruby.Programming向R ...
- 1月10日 ruby基础教程,查漏补缺; 2月22日 Exception补充
https://ruby-doc.org/core-2.5.0/Exception.html 1月20日练习完1,2章. 第一章 初探 ‘’单引号不执行转义符. \t 制表符.\n 换行符. p me ...
- 基础拾遗----RabbitMQ
基础拾遗 基础拾遗------特性详解 基础拾遗------webservice详解 基础拾遗------redis详解 基础拾遗------反射详解 基础拾遗------委托详解 基础拾遗----- ...
- Java基础拾遗(二)
(尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/76358523冷血之心的博客) 马上就要秋招了,新的一轮笔试面试马上 ...
- Java基础拾遗(一)
(尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/76358391冷血之心的博客) 马上就要秋招了,新的一轮笔试面试马上 ...
随机推荐
- 如何为开发项目编写规范的README文件
前言 了解一个项目,首先都是通过其Readme文件了解信息.如果你以为Readme文件都是随便写写的那你就错了.github,oschina git gitcafe的代码托管平台上的项目的Readme ...
- centos启动jar包
不挂断运行命令,日志输出到log.txt中 nohup java -jar boot-cms-module-system-2.0.1.jar >log.txt & Linux 运行jar ...
- Python使用pyautogui控制鼠标键盘
官方文档:https://pyautogui.readthedocs.io/en/latest/# 安装pyautogui模块 在 Windows 上,不需要安装其他模块. 在 OS X 上,运行 s ...
- Redis 事务在 SpringBoot 中的应用 (io.lettuce.core.RedisCommandExecutionException: ERR EXEC without MULTI)
我们在 SpringBoot 中使用 Redis 时,会引入如下的 redis starter <dependency> <groupId>org.springframewor ...
- Windows Android SDK下载安装,配置,异常问题解决教程
团队编程项目终于开始了,相信大家都在如火如荼的准备的当中,这里念半整理了一份还比较全面的关于 Android SDK的下载安装的教程,当然如果你说你们小组的实验环境选择的是Android studio ...
- java各种面试问题
二.Java多线程相关 线程池的原理,为什么要创建线程池?创建线程池的方式: 线程的生命周期,什么时候会出现僵死进程: 说说线程安全问题,什么实现线程安全,如何实现线程安全: 创建线程池有哪几个核心参 ...
- 本地启动tomcat的时候报java.util.concurrent.ExecutionException: java.lang.OutOfMemoryError: PermGen space
1.问题:我在tomcat中放入了大量的war包,启动的时候报:java.util.concurrent.ExecutionException: java.lang.OutOfMemoryError: ...
- 利用Session实现三天免登陆
什么是Session Session:在计算机中,尤其是在网络应用中,称为“会话控制”.(百度百科) Session:服务器端的数据存储技术. Session要解决什么问题 一个用户的不同请求(重定位 ...
- 124、Java面向对象之引用传递实例二,String类型按值传递
01.代码如下: package TIANPAN; /** * 此处为文档注释 * * @author 田攀 微信382477247 */ public class TestDemo { public ...
- kubernetes 1.5.2 部署kube-dns 踩过的坑
看了kubernetes 权威指南 遇见了dns这一块.于是便按照书上的方式部署了一下. 书上使用的方式是:kube2sky+etcd+skydns的方式.按照书上的yaml写了一遍,发现无论如何都无 ...