UPSERTって・・・

Date:

Share post:

今回はSQL(とEloquent)のお話(私が勉強不足でしたが)を書こうと思います。


一般的なテーブルへのCRUDで使用するSQLといえば

 ・SELECT(検索)

 ・UPDATE(更新)

 ・INSERT(挿入)

 ・DELETE(削除)

が挙げられますが、ある条件でレコードを検索して、存在しない場合は新しくレコードを追加し、存在する場合はそのレコードを更新するというケースがあった場合です。

今までの私は、レコードの取得状態を判定して適宜UPDATEとINSERTを行っておりました・・・。

そこで題名に書いたUPSERTです。

RDBMSにより差異がありますが複数回のSQLを発行せずに、(あれば)レコードの更新、(なければ)レコードの挿入ができます。

最近の業務で携わっているlaravelのEloquentの場合だと

 ・updateOrCreate

というのがあります。便利だなと思いました。

Related articles

画像検索の精度確認(4)

前回の投稿では、エンベディングの前処...

画像検索の精度確認(3)

過去の投稿を通して、TensorFl...

(ちょっとニッチな)FastAPI環境構築の巻(そ...

最近Tさんがすごい勢いで記事を書かれて...