スキップしてメイン コンテンツに移動

SQL での行数の count

* がいいのか

SQL を書いて行数を得るときなどによく書く↓これ。前から思っていたのだが、ここで * ではなく 1 と書いたりすることもあるが、何がいいのだろうか?

select count(*) from hoge_table?
select count(1) from hoge_table?

その答えは

ミックのサイトにあった。

サブクエリの SELECT 句を書くには、以下の3つの選択肢があります。

1.EXISTS (SELECT * FROM …)
2.EXISTS (SELECT 列名 FROM …)
3.EXISTS (SELECT 定数 FROM …)

 このうち、最も良いのは1.です。この書き方は、オプティマイザにどの列を使うべきかの選択を委ねることになります。そして、列にインデックスが張られていれば、実表を走査する必要はありません。

 ただし、例外的に2.や3.の方が1.よりも高速な場合もあります。古い DBMS では2.のように列名を指定した方が速いこともあります。また、Oracleその他の製品では、3.のように「SELECT 1 FROM …」など、定数を指定すると高速になります。この書き方は、行へのポインタさえ得られれば、実際の行を読む必要がないことを、DBMS に明示してやる効果があります。

 しかし、2.はもはや使う機会はないでしょうし、3.の書き方は意味的な混乱を招くので、基本的には1.を使うのが良いでしょう。

ちょっと違うけど

ここでは EXIST だけど count でも同じことなのかなと思っています。

コメント

このブログの人気の投稿

間違ったフォーマットのプログラムじゃないんだけど

以下エラーに対し、 ファイルまたはアセンブリ 'SSPI'、またはその依存関係の 1 つが読み込めませんでした。間違ったフォーマットのプログラムを読み込もうとしました。 以下環境で対応した話です。 VisualStudio2012(C# ASP.NET MVC4.0) IIS7.5 とあるところのdllを使用中 ASP.NETをIISに発行しようとしたら、上記エラーが発生。 他のプロジェクトでは問題なく発行できているのに、 何かと思ってみたら、google先生に尋ねてみると、 DLLファイルの対象プラットフォーム(32bit/64bit)が異なる とのことでした。 このサイトでは対処方法として、 運用環境のプラットフォームに合わせ、適切なランタイムファイルを配布してください。 と記載されていますが、今回の私のようにとあるところのdllを使用している場合などは、 そうもいかない場合もあるでしょう。 そこでdllを変更できない場合には、 IISのアプリケーションプールの設定で、 32bitアプリケーションを有効化してあげることで対応できます。 以下手順です。 コントロールパネル → 管理ツール → インターネット インフォメーション サービス (IIS) マネージャー を起動します。 変更したいアプリケーションを右クリックして、詳細設定を選択します。 32ビットアプリケーションの有効化をTrueに変更します。 もう一度発行します。 ここまでです。 簡単だけど知らないとなかなかはまるかなって気がしますね。 独特のくせなのかもしれません。 そして、次なるエラー発生中です・・・。

SQLServer2008でのトランザクションログの切り捨て方

SQL Server 2008でとあるDBのトランザクションログが一杯に。 BACKUP LOG DatabaseName WITH TRUNCATE_ONLY を使ってトランケートしようとしたら、 'TRUNCATE_ONLY' はBACKUP オプションとして認識されません。 との冷たい返事。2008で廃止されていたのを忘れていた。 SQL Server 2008 で廃止されたデータベース エンジンの機能@MSDN そこでヌルデバイスを使用してバックアップを取得する方法で、切り捨てを試みる。 BACKUP LOG DatabaseName TO DISK = ‘nul’ GO するとまた冷たい返事。 現在、データベースのバックアップが存在しないので、BACKUP LOG を実行できません。 2008では過去にフルバックアップを取得しておかないと、ランザクションのバックアップが取得できないことを忘れてた。てなわけで、まずはデータベースのフルバックアップを取得して、 BACKUP DATABASE DatabaseName TO DISK = ‘nul’ GO もう一度トランザクションのバックアップをして、やっと切り捨てれた。最初から単純にしておけばよかった・・・。

HP Pavilion Desktop PC h8-1080jp のSSDの交換方法

Windows起動時にDiskの読み取りエラーが発生し、 マシンが上がってこなくなってきたのでSSDを交換した。 HP製のマシンを使っているのだが、微妙にどう外すか戸惑った。 外し方が書いてあるのだが、とにかく見えにくい!! と言う訳で誰かの参考になればと思って、 以下にログを残しておきます。 側面を外します。 前面も外します。 真ん中の金具がねじが止まっているので外します。 ここまでは楽勝でした。 HDDが入ってるやつがなかなか外れない・・・と思っていたら、 よーく見ると赤枠のところに外し方が書いてあります。 奥にあるボタンを押す HDDが入っている箱(?)を上に持ち上げるようにすると外れます 外れるとこんな感じに。 後はケーブルを差し替えればOKです。 会社のノートPCも壊れるし、そういう時期なんだろうか・・・。 開けたら東芝の1.8インチHDDで、なかなかデータが吸い出せないし・・・。 やれやれです。