質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

Q&A

解決済

1回答

2161閲覧

大量のデータを、順番通りにDBに格納する方法を教えてください。Node, Sequelize, postgrSQL

shimon_

総合スコア26

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

0グッド

2クリップ

投稿2020/09/04 14:13

実現したいこと

約5000行に及ぶTSVファイル内のデータを、もとデータの順番通りにDBに格納したい。
ファイル内のデータは上から日付順で並んでおり、1行=1データとしてDBに格納します。

DBへの格納方法

もとファイルをStreamで読み込み、1行読み込んだタイミングでDB更新処理をしています。

発生している問題

DBを確認すると、行順がところどころずれた状態で格納されていました。
おそらく原因は、streamのlineイベントにおいて、テーブル更新処理が終了する前にループしているから、と推測しています。

質問

大量のデータを、順番に狂いなくDBに格納する方法をおしえていただけないでしょうか?
よろしくお願いいたします。

DBへデータを格納するコード

Node

1const fs = require('fs'); 2const readline = require('readline'); 3 4// モデルの読み込み 5const Day_info_total = require('../models/day_info_total'); 6Day_info_total.sync(); 7 8// もとファイルのパス 9const path = '../downloads/all/total/all.tsv'; 10 11var rs = fs.createReadStream(path, 'utf-8'); 12var rl =readline.createInterface({input: rs}); 13rl.on('line',(data)=>{ 14 var data = data.split('\t'); 15 // モデルの更新 16 Day_info_total.create({ 17  date: data[0], 18  time: data[1], 19  unixTime: data[2], 20  totalVideos: data[3], 21  totalViews: data[4], 22 totalComments: data[5], 23 }); 24});

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

momon-ga

2020/09/04 15:30

そもそもの前提条件、無視しちゃいますが DBの格納順って意味なくて、取得するさいにオーダーかけるものでは? そこにこだわる必要ってあります?
guest

回答1

0

ベストアンサー

大量のデータを、順番に狂いなくDBに格納する方法をおしえていただけないでしょうか?

そもそもRDBMSは「集合」を扱うものであり、「格納順」という概念がありません。
レコードの順番は「常に保証されない」という前提で考えるものです。

各データに順序付けて扱いたい場合は、自分であらかじめ順序を定義した列を追加するか、任意の列でオーダーをかけるものです。

それを理解した上で、どうしても「格納順」にこだわるのであれば、一行挿入するごとにトランザクションをコミットすれば良いんじゃないですかね。

投稿2020/09/04 16:01

編集2020/09/04 16:04
gentaro

総合スコア8947

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問