Gaiax Advent Calendar 2016 の21日目の記事です。 ActiveRecord の find_or_create_by で苦労したので、それをまとめておきたいと思います。 まずは、以下のような状況を仮定します。 あるタスクが完了したら、その日分の TaskReport の count をインクリメントする その日分のTaskReportレコードがあれば更新する、なければ作成する CREATE TABLE `task_reports` ( `id` int(11) NOT NULL AUTO_INCREMENT, `date` date DEFAULT NULL, `count` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) task_report = TaskReport.find_or_create_by(date: Dat
![ActiveRecord の find_or_create_by を確実に実行するには - Qiita](https://cdn-ak-scissors.b.st-hatena.com/image/square/4e01b1bd95c9fb52667e78190b0aa9b10b72c7f7/height=288;version=1;width=512/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Fadvent-calendar-ogp-background-f625e957b80c4bd8dd47b724be996090.jpg%3Fixlib%3Drb-4.0.0%26w%3D1200%26mark64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9QWN0aXZlUmVjb3JkJTIwJUUzJTgxJUFFJTIwZmluZF9vcl9jcmVhdGVfYnklMjAlRTMlODIlOTIlRTclQTIlQkElRTUlQUUlOUYlRTMlODElQUIlRTUlQUUlOUYlRTglQTElOEMlRTMlODElOTklRTMlODIlOEIlRTMlODElQUIlRTMlODElQUYmdHh0LWNvbG9yPSUyMzNBM0MzQyZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT01NiZ0eHQtY2xpcD1lbGxpcHNpcyZ0eHQtYWxpZ249bGVmdCUyQ21pZGRsZSZzPTMxZDU3ZDg3NThhY2UzOTAxMDNjMDBkNzc3ZjAzNWI1%26mark-x%3D142%26mark-y%3D151%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTYxNiZ0eHQ9JTQwa3lyaWVsZWlzb24mdHh0LWNvbG9yPSUyMzNBM0MzQyZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT0zNiZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZzPTU2NDk4ZTZjMWU2NDQxZTFlZWUwZGEzMTc1N2MwNzdm%26blend-x%3D142%26blend-y%3D491%26blend-mode%3Dnormal%26s%3D4e8f775440dbd90eb7a27d5ebb6e91dd)