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

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

ただいまの
回答率

88.10%

SQLiteのデメリットについて

解決済

回答 3

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 10K+

score 37

SQLiteというものについて調べているとき、長所と短所が出てきたのですが、今回は短所についての質問です。
短所としてこちらのサイトでは

データがあくまでもローカルに保持されるために、複数のWebサーバーからアクセスを受けることができない

と書いてあるのですが、「複数のWebサーバーからアクセスを受けることができない」という点が短所になる理由についてよくわかりません。
たとえば、

  • 各ユーザーのデータはSQLiteを使ってローカルで管理して、サーバー側(MySQL, PostgreSQLなど)へSQLiteのデータを定期的にアップロードする
  • ローカルで完結する程度のアプリケーションでデータを扱いやすくするためにSQLiteを使う

というローカルでのデータをより扱いやすくする使い道が本道でそもそも複数のWebサーバーからアクセスを受けるようなものではないので短所といえるものではないと思うのですが...
知らないだけでSQLiteでWebサーバーからアクセスを受ける場合というのもあるのでしょうか?

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

回答 3

checkベストアンサー

+5

ローカルでのデータをより扱いやすくする使い道が本道でそもそも複数のWebサーバーからアクセスを受けるようなものではない

日本語の言い方の問題に近い話です。「複数のサーバからアクセスして使えない」というのを、MySQLなどと比較して「欠点」と見るか、最初から「それとは用途の違うもの」と見るか、という話です。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/10/04 16:39 編集

    ご回答ありがとうございます。
    質問文の記事の内容については「SQLiteと他のDBMSを比較するときにクライアントサイドではなくサーバサイドでの利用を前提にしているために「複数のWebサーバーからアクセスを受けることができない」という点が短所になる」ということだったと理解しています。
    サーバサイドでの利用を前提にしているにも関わらず「そもそも用途が違ってローカルで使うのではないか」ということを質問していたということになるのですね。
    少し理解できたような気がします。

    キャンセル

+4

ブログを書くのはハッカーだけじゃないよ。
質問者さんに毛が生えた程度の人や、もっとひどい時にはそれ以下の人も大勢ブログ記事を残してたりする。

例えばMySQLの項目

「LAMP」という言葉があります。
Linux・Apache・ MySQL・PHPの頭文字を取ったものです。
この言葉の中にあるように、Webアプリケーションとして連携という点に置いて長所があると思います。

これはMySQLが有名って言いたいだけで、それ以外の何の説明にもなってないよね。

、高速である分いくつかの機能が意図的に盛り込まれていません。
(カーソル、副問い合わせ、トランザクション機能、結合機能、トリガ、ストアドプロシージャ、複製機能など)

嘘だろ…MySQLってこんなに低機能だっけ…?
当時既に5.6であるわけで公式マニュアル見れば上記の機能は大抵存在すると分かるんだけど、
いったいバージョンいくつの話なんだろう。


まぁ、要するにまともなエンジニアがレビューすれば突き返すレベルの記事に見えるのだけど、
真に受ける価値あるの?私は無いと思うなぁ。

一応著者のフォローをしておくと、こんな感じなんじゃないかな。

  • Web制作会社の社内ブログであり、特に上位者のスキルレベルも低くレビューが困難だった
  • 短い期間で1記事仕上げるというノルマが課せられ、十分に文章を推敲したり深い調査をする時間が与えられなかった
  • 6年前の記事なので、きっと著者もスキルアップしてるけど退職済み等の事情で添削もできない

追記

既に理解しているかもしれないけど、ローカルと呼ばれる箇所が2点あることに注意してね。

  • Webサーバーのマシン内のハードディスク ←ブログ記事でデメリットだ!と言ってる箇所
  • クライアントのマシン内のハードディスク ←質問文でSQLiteの使用箇所と考えている

SQLiteってのはハードディスク内のファイルを書き換えるってだけ。
MacOSやWindows、Linux用のプログラムも配布されてて、どこにでもインストールして使えるからね。
Androidでは設定ファイルの書き換えにSQLite利用しているし…

ブログ記事の作者としては「Webアプリ」を構築するという観点のみで見た、
POSTしたデータをWebサーバーで管理する手法として評価している。

  • MySQL: ○
  • SQLite: ×

負荷が増えてサーバーの台数を2台に増やした場合、1台目と2台目のハードディスク内のデータを共有することが難しいからね。
でも難しいとは言ったけど、無理ではない。
異なるマシン間でファイルの同期をとったり共有する手法なんて山ほどある。

例えばmemocachedというマシンのメモリ領域を使った低機能超高速な揮発性DBがあるんだけど、
FacebookがこれをクラスタリングしてKSVサーバとして運用する奮闘記的な情報が下記サイトで公開されている。
Facebookの数千台規模のmemcached運用について - ゆううきブログ

memcachedに出来るならSQLiteに出来ない道理はない。
asahina1979さんがこっそり出してくれた下記のサイトがSQLiteのサーバー利用だね。
https://www.sqlite.org/cvstrac/wiki?p=SqliteNetwork

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/10/04 16:26

    質問文で引用したSQLiteのデメリットはリンク先の記事だけでなく、weblioなど個人的に信頼できると考えているサイトでも掲載されていた情報だったので質問しました。「まともなエンジニア」になれるように今後もできる限りの努力をしていこうと思います。回答ありがとうございました。

    キャンセル

  • 2017/10/04 17:35

    私も偉そうな事を言ってるけど、
    業務で急かされたり、認識を誤って沢山の誤ったアウトプットをしてきたからね。

    大事なのは誤りを認めてすぐに修正することだね。
    誤りを含んだ文章ってのは一気に信憑性がなくなるから、誤った記事を出した時点でダメージだけど、それが放置されているのは非常によろしくない。

    キャンセル

+3

ローカルでのデータをより扱いやすくする使い道が本道で

という認識が間違っています。

メリットデメリットを挙げるというのは、必ず前提や比較対象が必要です。
お書きのデメリットは、サーバーサイドのDBMSとして、MySQLやPostgreSQL等と比較した場合の物です。

ローカルというのは、クライアントサイドの事だと思いますが、別にSQLiteはクライアントサイドで使うのが本道という事ではありません。
クライアントサイドで、クライアントローカルで使うことが前提でDBMSを比較すると、サーバーサイドのDBMS比較でのメリットデメリットと違ってくるのは当然です。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/10/04 16:32

    > お書きのデメリットは、サーバーサイドのDBMSとして、MySQLやPostgreSQL等と比較した場合の物です。

    SQLiteと他のDBMSを比較するときにクライアントサイドではなくサーバサイドでの利用を前提にしているために「複数のWebサーバーからアクセスを受けることができない」という点が短所になるのですね。大変分かりやすかったです。ご回答ありがとうございました。

    キャンセル

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

  • ただいまの回答率 88.10%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る