MW211 EXIT

devlog
MSSQL/Profiler(1)概要
2015年05月26日
監視機能である「SQL Server Profiler」とは。

この機能は、「SQL Server」に対する命令(SQL文など)を
間に入ってトレースするものである。

これにより、どのようなSQL文が「SQL Server」側に渡ったのか確認できる。
一方で、間に入るということは、「SQL Server Profiler」が
情報を一次受けして「SQL Server」に取り次ぐ感じになるので性能が落ちる。
よって、本番環境ではあまり多用せず、
調査など特別な場合のみに限って用いた方がよい。
分類:MSSQL
MSSQL/VACUUM相当
2015年05月25日
MSSQLにPostgreSQLの「VACUUM」に相当する処理があるのか?必要なのか?

ない、必要ない。
分類:MSSQL
SQL/JOIN
2015年05月20日
単なる「JOIN」は「INNER JOIN」の略
分類:MSSQL
MSSQL/マッチング・後編(Ⅱ)
2015年05月14日
MERGE文はあきらめきれないあなたに。

【案1】CASE文で差分がなければ現状維持の値を代入する
┌──────────────────────────────────────┐
│MERGE INTO [旧表]                                                           │
│    USING [新表]                                                            │
│       ON [新表].[キー] = [旧表].[キー]                                     │
│    WHEN MATCHED THEN                                                       │
│        UPDATE SET [列]       = [新表].[列],                                │
│                   [更新日時] = CASE                                        │
│                                  WHEN [旧表].[列] = [新表].[列] THEN       │
│                                    [旧表].[更新日時]                       │
│                                  ELSE                                      │
│                                    getdate()                               │
│                                END                                         │
│    WHEN NOT MATCHED BY TARGET THEN                                         │
│        INSERT (                                                            │
│                [キー],                                                     │
│                [列],                                                       │
│                [更新日時]                                                  │
│            ) VALUES (                                                      │
│                [新表].[キー],                                              │
│                [新表].[列],                                                │
│                getdate()                                                   │
│            );                                                              │
└──────────────────────────────────────┘

【案2】まず重複するものを除いたからMERGEを行う
┌──────────────────────────────────────┐
│MERGE INTO [旧表]                                                           │
│    USING (                                                                 │
│        SELECT *                                                            │
│            FROM [新表]                                                     │
│            WHERE NOT EXISTS (                                              │
│                      SELECT *                                              │
│                          FROM [旧表]                                       │
│                          WHERE [旧表].[キー] = [新表].[キー]               │
│                            AND [旧表].[列]   = [新表].[列]                 │
│                  )                                                         │
│    ) AS [新表]                                                             │
│       ON [新表].[キー] = [旧表].[キー]                                     │
│    WHEN MATCHED THEN                                                       │
│        UPDATE SET [列]       = [新表].[列],                                │
│                   [更新日時] = getdate()                                   │
│    WHEN NOT MATCHED BY TARGET THEN                                         │
│        INSERT (                                                            │
│                [キー],                                                     │
│                [列],                                                       │
│                [更新日時]                                                  │
│            ) VALUES (                                                      │
│                [新表].[キー],                                              │
│                [新表].[列],                                                │
│                getdate()                                                   │
│            );                                                              │
└──────────────────────────────────────┘

【案2】が拡張性があってよさげだ。

※NULL値の比較に注意
分類:MSSQL
MSSQL/非NULL列の追加
2015年05月13日
┌──────────────────────────────────────┐
│ALTER TABLE [表] ADD [列] [int] NOT NULL;                                   │
└──────────────────────────────────────┘
「NOT NULL」制約の列を後から追加した場合、エラーとなる。
追加した列の初期値が「NULL」だからだ(矛盾してしまう。

なので、既定値付きなら問題ない。
┌──────────────────────────────────────┐
│ALTER TABLE [表] ADD [列] [int] NOT NULL DEFAULT 0;                         │
└──────────────────────────────────────┘

つまり、最初のやつは以下のような指定だったわけだ(これは矛盾している)。
┌──────────────────────────────────────┐
│ALTER TABLE [表] ADD [列] [int] NOT NULL DEFAULT NULL;                      │
└──────────────────────────────────────┘

でも、こういうことをやりたいケースというのは多々ある。

これを実現するには迂回する形で3ステップ必要となる。
┌──┬───────────────────────────────────┐
│(1) │ALTER TABLE [表] ADD [列] [int] NULL;                                 │
├──┼───────────────────────────────────┤
│(2) │UPDATE [表] SET [列] = 0;                                             │
├──┼───────────────────────────────────┤
│(3) │ALTER TABLE [表] ALTER COLUMN [列] [int] NOT NULL;                    │
└──┴───────────────────────────────────┘
  (1) ひとまずNULL許容属性で追加する
  (2) NULLじゃない値にする
  (3) NOT NULL制約をつける
分類:MSSQL
VB.net/実行ファイル名を変更
2015年05月12日
「bin\Release」もしくは「bin\Release」に生成される実行ファイル名を変更する方法。

もちろん、生成後に直接変更しても問題ないのだが、
最初からそのファイル名にするには。

「MyProject/アプリケーション」で「アセンブリ名」を
名づけたい実行ファイル名(拡張子は不要)にする。
分類:VB.net
VB.net/デバッグログ
2015年05月11日
【ダイアログに表示】
┌──────────────────┬───────────────────┐
│MsgBox                              │ダイアログに出力                      │
│MessageBox.Show                     │                                      │
└──────────────────┴───────────────────┘
 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
【出力ウインドウに表示】
┌──────────────────┬───────────────────┐
│System.Diagnostics.Debug.Write      │出力ウィンドウに改行しないで出力      │
│System.Diagnostics.Trace.Write      │                                      │
├──────────────────┼───────────────────┤
│System.Diagnostics.Debug.WriteLine  │出力ウィンドウに改行して出力          │
│System.Diagnostics.Debug.Print      │                                      │
│System.Diagnostics.Trace.WriteLine  │                                      │
│System.Diagnostics.Trace.Print      │                                      │
├──────────────────┼───────────────────┤
│System.Diagnostics.Debug.WriteIf    │条件付きで                            │
│System.Diagnostics.Trace.WriteIf    │      出力ウィンドウに改行しないで出力│
├──────────────────┼───────────────────┤
│System.Diagnostics.Debug.WriteLineIf│条件付きで出力ウィンドウに改行して出力│
│System.Diagnostics.Trace.WriteLineIf│                                      │
└──────────────────┴───────────────────┘
  ※「.Debug.」はDebug時のみ出力(「.Trace.」はReleaseでも出力)
  ※出力ウインドウは「Ctrl+Alt+O」で表示できる
  ※イミディエイトウィンドウに出力されている場合は
    「ツール>オプション>デバッグ>全般」の
    「□出力ウィンドウの文字をすべてイミディエイトウィンドウにリダイレクトする」
    のチェックを外す
 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
分類:VB.net
VB.net/ダイアログ定数
2015年05月10日
【アイコン表示】
┌───────────────────┬──────────────────┐
│MessageBoxIcon.None                   │アイコンなし                        │
├───────────────────┼──────────────────┤
│vbInformation                   (=64)│情報アイコン                        │
│MsgBoxStyle.Information               │[i]白地に青文字○                  │
│MessageBoxIcon.Information            │                                    │
│MessageBoxIcon.Asterisk               │                                    │
├───────────────────┼──────────────────┤
│vbExclamation                   (=48)│警告アイコン                        │
│MsgBoxStyle.Exclamation               │[!]黄地に黒文字△                  │
│MessageBoxIcon.Exclamation            │                                    │
│MessageBoxIcon.Warning                │                                    │
├───────────────────┼──────────────────┤
│vbCritical                      (=16)│エラーアイコン                      │
│MsgBoxStyle.Critical                  │[×]赤地に白文字○                  │
│MessageBoxIcon.Error                  │                                    │
│MessageBoxIcon.Hand                   │                                    │
│MessageBoxIcon.Stop                   │                                    │
├───────────────────┼──────────────────┤
│vbQuestion                      (=32)│疑問アイコン                        │
│MsgBoxStyle.Question                  │[?]白地に青文字○                  │
│MessageBoxIcon.Question               ※非推奨(曖昧なので上記いずれかで代用)│
└───────────────────┴──────────────────┘
 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
【ボタン表示】
┌───────────────────┬──────────────────┐
│MsgBoxStyle.OkOnly               (=0)│[OK]                                │
│MessageBoxButtons.OK                  │                                    │
├───────────────────┼──────────────────┤
│MsgBoxStyle.OkCancel             (=1)│[OK]・[キャンセル]                  │
│MessageBoxButtons.OKCancel            │                                    │
├───────────────────┼──────────────────┤
│vbYesNo                          (=4)│[はい]・[いいえ]                    │
│MsgBoxStyle.YesNo                     │                                    │
│MessageBoxButtons.YesNo               │                                    │
├───────────────────┼──────────────────┤
│vbYesNoCancel                    (=3)│[はい]・[いいえ]・[キャンセル]      │
│MsgBoxStyle.YesNoCancel               │                                    │
│MessageBoxButtons.YesNoCancel         │                                    │
├───────────────────┼──────────────────┤
│vbRetryCancel                    (=5)│[再試行]・[キャンセル]              │
│MsgBoxStyle.RetryCancel               │                                    │
│MessageBoxButtons.RetryCancel         │                                    │
├───────────────────┼──────────────────┤
│vbAbortRetryIgnore               (=2)│[中止]・[再試行]・[無視]            │
│MsgBoxStyle.AbortRetryIgnore          │                                    │
│MessageBoxButtons.AbortRetryIgnore    │                                    │
└───────────────────┴──────────────────┘
 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
【ボタン値】
┌───────────────────┬──────────────────┐
│vbOK                             (=1)│OK                                  │
│DialogResult.OK                       │[OK]                                │
├───────────────────┼──────────────────┤
│vbCancel                         (=2)│Cancel                              │
│DialogResult.Cancel                   │[キャンセル]                        │
├───────────────────┼──────────────────┤
│vbYes                            (=6)│Yes                                 │
│DialogResult.Yes                      │[はい]                              │
├───────────────────┼──────────────────┤
│vbNo                             (=7)│No                                  │
│DialogResult.No                       │[いいえ]                            │
├───────────────────┼──────────────────┤
│vbAbort                          (=3)│Abort                               │
│DialogResult.Abort                    │[中止]                              │
├───────────────────┼──────────────────┤
│vbRetry                          (=4)│Retry                               │
│DialogResult.Retry                    │[再試行]                            │
├───────────────────┼──────────────────┤
│vbIgnore                         (=5)│Ignore                              │
│DialogResult.Ignore                   │[無視]                              │
├───────────────────┼──────────────────┤
│DialogResult.None                     │Nothing(モーダルダイアログが継続)   │
└───────────────────┴──────────────────┘
 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
【既定ボタン指定】
┌───────────────────┬──────────────────┐
│vbDefaultButton1                 (=0)│一番目のボタンが既定ボタンとなる    │
│MsgBoxStyle.DefaultButton1            │                                    │
├───────────────────┼──────────────────┤
│vbDefaultButton2               (=256)│二番目のボタンが既定ボタンとなる    │
│MsgBoxStyle.DefaultButton2            │                                    │
├───────────────────┼──────────────────┤
│vbDefaultButton3               (=512)│三番目のボタンが既定ボタンとなる    │
│MsgBoxStyle.DefaultButton3            │                                    │
├───────────────────┼──────────────────┤
│vbDefaultButton4               (=768)│四番目のボタンが既定ボタンとなる    │
└───────────────────┴──────────────────┘
 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
【モーダル指定】
┌───────────────────┬──────────────────┐
│vbSystemModal                         │システムモーダルにする              │
│MsgBoxStyle.SystemModal               │                                    │
├───────────────────┼──────────────────┤
│vbApplicationModal                    │アプリケーションモーダルにする      │
│MsgBoxStyle.ApplicationModal          │                                    │
└───────────────────┴──────────────────┘
 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
【その他】
┌───────────────────┬──────────────────┐
│vbMsgBoxHelp                          │ヘルプ テキスト                     │
│MsgBoxStyle.MsgBoxHelp                │                                    │
├───────────────────┼──────────────────┤
│vbMsgBoxRight                         │右寄せ表示                          │
│MsgBoxStyle.MsgBoxRight               │                                    │
│MessageBoxOptions.RightAlign          │                                    │
├───────────────────┼──────────────────┤
│vbMsgBoxRtlReading                    │右から左へ表示                      │
│MsgBoxStyle.MsgBoxRtlReading          │            (ヘブライ語・アラビア語)│
│MessageBoxOptions.RtlReading          │                                    │
├───────────────────┼──────────────────┤
│vbMsgBoxSetForeground                 │前面に表示                          │
│MsgBoxStyle.MsgBoxSetForeground       │                                    │
├───────────────────┼──────────────────┤
│MessageBoxOptions.DefaultDesktopOnly  │アクティブデスクトップに表示        │
│MessageBoxOptions.ServiceNotification │                                    │
└───────────────────┴──────────────────┘
 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
分類:VB.net
VB.net/終了
2015年05月09日
「End」

Cの「exit();」みたいなもの
分類:VB.net
VB.net/return文
2015年05月07日
VB6.0(ExcelVBA)の時代は関数の戻り値をreturn文で返却できなかった。
(関数名に代入する形)
これは、GoSub文のためにreturn文が使用されていたためだ。

VB.netとなってからは、Cなどと同じ様にreturn文で返却できるようになった。
分類:VB.net
前へ 1 … 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 … 156 次へ