× 說心事 政治時事 生活 運動 汽車 機車 自行車 相機 科技 理財 旅遊美食 娛樂 健康 美麗時尚 人際關係 文學故事 關於《思書》
吃喝玩樂 關於《思書》


Rails 的 joins 中 select 的欄位不會在 console 中顯示


紅寶鐵軌客
來關注...
關注/停止關注:紅寶鐵軌客
關注有什麼好處?:當作者有新文章發佈時,「思書」就會自動通知您,讓您更容易與作者互動。
×
現在就加入《思書》,你就可以關注本作者了!
《思書》是一個每個人的寫作與論壇平台,特有的隱私管理,讓你寫作不再受限,討論更深入真實,而且免費。 趕快來試試!
還未加入《思書》? 現在就登錄! 已經加入《思書》── 登入
Rails 使用中,折磨中,享受中......
2018/07/16
31   0  


寫網頁,少不了要用上 joins,在 rails 中,沒指明,joins 就是 inner joins,也就是交集,這個很好用,特別是配合上 select,更可以把指定的兩個 tables 中的欄位帶入變數中。 比較討厭的是,如果各位跟我一樣,喜歡用 rails c 中驗證 SQL,conole 並不會顯示出來,舉例來說:

test = User.joins(:blog).select('user.id, user.name, blog.title')

這時用 console 執行後,卻會顯示如此:

irb(main):xx:0> User Load (0.9ms)  SELECT users.id,users.name,blog.title FROM "users" INNER JOIN "blog" ON "blog"."user_id" = "users"."id"
=> #<ActiveRecord::Relation [#<User id: 1, name: "Andy">]>

很奇怪的,明明有指定 blog.title 為什麼怎麼試就是沒有顯示出來?

其實是有的,只是 rails console 沒顯示,我也不知道為什麼,照道理應該要,我想任何平台總有些不足的,來在 rails c 中驗證一下:

irb(main):xx:0> test.first.title
=> "第一筆 blog 的 title"

確定有,只是 console 沒顯示! 

還有一個常用的,就是當兩個 joins 的 table 都有一樣的名稱時,怎麼指定?就用個 as:

User.joins(:blog).select('user.id, user.name, blog.title, blog.id as blog_id')

很簡單吧,如果要把所有的 columns 都用 select 帶入,就是:user.*,只是,真有必要嗎?有時太懶就要都用一些記憶體,一笑!


喜歡作者的文章嗎?馬上按「關注」,當作者寫新文章時,思書™就會 email 通知您。 思書是公開的寫作平台,創新的多筆名寫作方式,能用不同的筆名探索不同的寫作內容,無限寫作創意,更保護作者與文章中人物的隱私,思書不只線上寫作方便,還可以整理文章成一本線上書,而且這些都是免費的,如果您喜歡寫作分享,一定要來試試! 《 加入思書》
思書™是自由寫作平台,本文為作者的個人立場與意見。
關於作者

很久以前就是個「寫程式的」,其實,什麼程式都不熟⋯⋯
就,這會一點點,那會一點點⋯⋯



標籤: joins select x 1 rails x 34

分享:



參與討論!
×
現在就加入《思書》,馬上參與討論!
《思書》是一個每個人的寫作與論壇平台,特有的隱私管理,用筆名來區隔你討論內容,讓你的討論更深入,而且免費。 趕快來試試!
還未加入《思書》? 現在就登錄! 已經加入《思書》── 登入