読者です 読者をやめる 読者になる 読者になる

Code for final

ふぁいなる向けのコード置き場です。すでにコードじゃないこともいっぱい。

SQL Serverでselectした結果のデータをinsert文としてSQLでエクスポートする方法。

SQL Server

SQLでselectしたデータをinsert文として出力したいときがあると思います。
初期データとしていれたデータを構築時にSQL流すだけで構築できるようにしたい場合とかです。

OracleSQL Developerの感覚でManagement Studioでエクスポートしようとしたらできないところから始まりました。
Oracleだと結果をエクスポートって簡単にできます。結果のグリッドでエクスポートを選んでクリップボードにinsert文を出力するとか朝飯前です。

そんな感じでOracleに慣れていたのでManagement Studioで結果のグリッドを選んでもファイル出力しかできません。

そこで調べるとManagement Studioにはスクリプトの生成という機能があり、テーブルからinsert文を生成してくれるというドンピシャな機能がありました。
これだ!と思いウィザードを進めると条件を入力するところがありません。。

そうです。テーブルの全データしか出力できないんです。
大は小を兼ねるということでこれで事足りるときもありますが、一部データを出力したいときもありますがな。

これはどうすっかなーと小一時間考えて思いつきました。
一時的にテーブルに作るしかないと。
幸いSQLとは便利なものでintoを使うと簡単にテーブルを作れます。
以下のような感じのSQLで。

select *
into temp_hogehoge
from hogehoge
where col = 'xxxx'

で、この一時的なテーブルをManagement Studioでスクリプト生成すれば完成です。
ちなみに詳細設定でデータのみにすることを忘れずに。
クリップボードにも出せます。

まとめると、SQLServerでselectした結果のデータをinsert文としてSQLでエクスポートしたい場合は、select intoで一時テーブルを作ってスクリプト生成するべし。

ちなみにこの方法はSQL Server 2008*1での話なので、最新バージョンではOracleみたいにできるようになっているかもしれません。いや、きっとできるはず。

この方法を思いつくのに意外と時間かかったので忘れないように記録しておきます。

*1:なんでこんな10年前ほどのバージョンを使っているかというと顧客指定だからです

SQL ServerにCSVファイル or Excelファイルからデータをインポートする際に注意(NOT NULLと改行)すること。

SQL Server

SQL Serverで開発システムの場合、テスト環境を構築する際に手っ取り早くデータをいれるときはManagement Studioのデータインポート機能を使うと思います。

そこで久々に使ったんですけど、ちょっとはまったので今後も忘れないように記録しておきます。

たいていは設計時にねたをExcelにまとめていると思うのでそこからデータインポートすると思います。

その際、Excelをそのまま入れるかCSV(フラットファイル)にして入れるかでそれぞれ注意するべきところが違うことが分かりました。

Excelファイルをインポート

NOT NULLの項目にはそのまま入らない。

varcharなどでNOT NULL制約があるカラムに対してExcelのセルが空欄のままだとNULLをいれるようとしてこけます。
この場合、空欄セルにデータで使われていない文字(★など)をいれといて入れた後にupdateで空文字にしましょう。
以下のようなSQLです。

update hogehoge
set col = ''
where col = '★'
セルに改行があるとそのまま入らない。

セル内に改行があると失敗します。 この場合、Excelで改行をまずデータで使われていない文字(■など)に置換して入れた後に改行に置換します。
Excelの改行コードは置換のときにCtrl+Jキーを押すと入力できます。見えませんけど。
以下のようなSQLです。

update hogehoge
set col = replace(col, '■', CHAR(13) + CHAR(10))
CSVに比べてエラーメッセージが不親切

な気がします。なのでエラーメッセージが何を言っているかわからない場合はCSVインポートに切り替えてみるのも一つの手です。
CSVでもそれほど親切なエラーメッセージはでませんが。

CSVファイルをインポート

セルに改行があるとそのまま入らない。

CSVでもこれは同じです。

50文字以上ある場合そのまま入らない。

1項目が50文字以上あるはCSV取り込み時の詳細設定で文字数を変更する必要があります。
なぜかデフォルトすべて50になってました。
これに気付かずにテーブルより桁数が少ないのに切り捨てましたみたいなエラーがでてはまりました。

まとめ

上記のような感じなのでおすすめは50文字以上のデータがあるテーブルはExcelで、それ以外はCSVで試して最終的にだめならCSVでエラーをつぶす。ですがね。

ちなみにこれはSQL Server 2008*1の場合ですので最近のバージョンだと違うかもしれません。というか改善されていてほしい。

*1:なんでこんな10年前ほどのバージョンを使っているかというと顧客指定だからです

JenkinsでビルドしてCheckstyleでエラーになることがあることを初めて知った日。

Jenkins Java Checkstyle

Javaで開発していてJenkinsでビルドを自動化している環境ならついでにCheckstyleで静的解析でもしておくかーみたいな感じで、 ついてくると思います。

仕事で提供されたJenkinsの環境もその一つでした。

で、いままでJenkinsのビルドが通っていたのにあるプルリクエストをマージしてから失敗するようになりました。

原因を見るとCheckstyleのところでfailとでている。

Checkstyleでfail???

僕みたいなにわかJava使いはCheckstyleは静的解析して警告だけ出してくれるものと思ってたのでこのエラーは意味不明でした。

これを機に調べるとCheckstyleもレベルがあって"error"と"warning"と"info"があるみたいですね。
Javaのプロジェクト結構やってますが、初めて知りました。

だいたいCheckstyleの定義ファイルは上から降ってきますからね。新規開発でも過去のを流用したり。
定義ファイルまで書けるようになる必要はないでしょう。

なので僕みたいにCheckstyleをなんとなく使っているひとはCheckstyleにはレベルがあり、CIでエラーにすることもできる。とだけ覚えておきましょう。

ちなみに今回の件は、JavaでよくやりがちなStringを==比較しているのがerrorレベルでした。修正したら通るようになりました。
僕がコーディングしたわけではないですが、.NETerはやっちゃいますよね。気持ちはわかります。

SourceTree v1.9以降のバージョンをアカウント登録せずに使用する方法。

Git SourceTree

会社でGitを使ったプロジェクトをやっており、慣れ親しんだSourceTree(v1.9.6)をいれるかーと思って、インストールして起動し、ウィザードを進めていくと以下の画面が出現。

f:id:finalstream:20161016180457p:plain

家だったら自分のアカウントでログインするけど客先のネットワークだし、変にログインはしないでおこうと思ってスキップを探すけどスキップするところがない。どっちのボタンを押しても先に進めない。

あーウィザードを閉じればいいのかと思って閉じるとSourceTreeが起動しない。

もしや…と思って調べてみるとv1.8.2あたりで登録が必須となったらしい。

回避方法としてライセンスファイルみたいなのをどこかに配置すればできるっぽいって書いてあったけど、客先のネットワークにファイルを持ってくるのが面倒なのでパス。
昔使ってたv1.4とかはまったくそんな必要なかったのになー。

じゃあ、旧バージョンでも使うかということで公式サイトを探すけど、ダウンロードできるようなところがない。

怪しいサイトには旧バージョンがあるけど、会社(しかも客先)のマシンにいれてウイルスでも検出されたら大惨事になるので、とても怖くてできない。

ググって以下の記事内にダウンロード先を発見した。

answers.atlassian.com

URLを見るとAtlassianのサーバっぽいので安全みたい。

というわけで、SourceTree v1.9以降のバージョンをアカウント登録せずに使用する方法はないので、旧バージョン(v1.7.0)を使用するしかないです。

旧バージョンで一番新しそうなv1.7.0のダウンロードは以下からできますが、そのうち消えるリスクもあるので客先ネットワーク、オフライン環境等で使用する予定のある方はダウンロードしておいたほうがいいかも。

https://downloads.atlassian.com/software/sourcetree/windows/SourceTreeSetup_1.7.0.32509.exe

v1.7.0は最新版とはインタフェースは異なるものの主要な操作はできるのでまったくもって問題ないです。そしてそんなに古くないです。(2015年くらいやと思う)

2016/11/26 追記

しばらくそのまま使えてたんですけど、30日を過ぎたあたりで使用を続けるには登録してくださいというようなメッセージが表示されて使えなくなりました。
なので上記の方法で使えるのは30日間限定になります。
その後はAttlassianにログインして「New SourceTree License」をクリックしてライセンスファイルをダウンロードしてインポートすることで継続して使えるようになりました。

PCをシャットダウンしてもUSB HDDの電源がOFFにならない場合、OFFにする方法。

PC

最近、PCを買い替えてしばらく普通に使っていたんですけど、ある異変に気付きました。

PCの電源を落としてもHDDのランプがついたままなのです。回転もしてるみたいです。

なんで?

調べてみると最近のパソコンはPCの電源が入ってない時でも、スマホとか充電できるように常にUSBに給電している仕様になっているみたいです。

まー場合によってはありがたいときもあるかもしれないけど、そんな機能使わないひと、知らないひとには電気代が無駄にかかる余計な仕様になったんですね。としか思えません。

で、このPCがついていないときもUSBに給電し続けるありがた迷惑な機能はOFFにすることができます。*1

PCがついていないときに動くものなので、Windowsの設定ではどうしようもできません。
ではどこにあるのかというと、BIOSにあるのです。

僕が持っているPC(ASUSマザーボード自作PCとHPのノート)はどちらも設定できました。

マザーボードやPCメーカーによってBIOSの起動方法や設定方法は違うので詳しくは各マニュアルなどを見ることをおすすめします。

以下にASUSマザーとHPのノートの設定方法を記載します。同じメーカーでもモデルによって違うかもしれませんので参考にしてください。

Mother/PC BIOS起動方法 BIOS設定 OFFとなる設定値
ASUS(Z170) DELキー Advanced > APM Configuration > ErP Ready 有効(S4+S5)*2
HP(Spectre13) ESCキー連打 > F10 SystemConfiguration > USB Charging Disabled


今回のまとめですが、PCをシャットダウンしてもUSBに給電し続けるありがた迷惑な機能はBIOSの設定でOFFにすることができるので困っているかたは試してみてください。

*1:できないPCもあるかもしれません。

*2:S4は休止状態、S5はシャットダウン状態を表します。

"Rextester" ブラウザ上でいろいろな言語(C#, Java, Ruby...)を実行して、結果を確認することができるサービス。

Good WebService C# SQL Ruby Java

ついこないだいろんなDBMSSQLを実行できるというサービス*1を見つけて興奮していたんですが、 SQLだけでなく、いろんな言語をオンラインでソースコードをテスト実行できるという究極のサービスを見つけてしまいました。

Rextesterはブラウザ上で実行環境を切り替えて、いろんな言語の実行結果をすぐに確認できるサービスです。

2016/09/25現在、対応しているのは以下の31言語です。

やばいです。多すぎです。ほとんどの言語が試せます。知らないのもちらほらありますが。

SQL FiddleでエラーになったOracleとかも普通にいけます。主要DBMSもサポートしています。

しかも、実行環境はプルダウンで変更するだけで、Hello Worldのテンプレート付きです。

なんと入力補完も出ます。(出ない言語もありますが、C#Javaは確認できました) f:id:finalstream:20160925195903p:plain

言語を勉強したいけど環境を作るまでもないときはありがたく使わせていただきましょう。


使用方法は説明が不要なくらい簡単です。

まず、以下のページにいきます。

http://rextester.com/

以下の様な画面が表示されます。(デフォルトはC#

f:id:finalstream:20160925195702p:plain

あとはコードを書いて、左下にある"Run it"ボタンを押すだけで実行結果が下に表示されます。

言語を変更する場合は上部にあるLanguageのプルダウンから変更するだけです。

こりゃ便利!

ブログでよく使うMarkdownの書き方を忘れたときにみるもの。

Markdown

ドキュメントを書くのに便利なMarkdown記法ですが、まだイマイチ身についていなく、久々にブログを書くと忘れたりするのでよく使うものをφ(..)メモメモ


文字修飾

やりたいこと 書き方 Preview
太字 **sample text** sample text
下線 <u>sample text</u> sample text
取り消し ~~sample text~~ sample text
<font color="crimson">sample text</font> sample text
サイズ <span style="font-size: 200%>sample text</span> sample text

フォントの色、サイズはmarkdownでは描けないのでhtmlを直接書く。


改行

行末に半角スペースを2ついれる。
ただし、連続して改行を入れる場合は<br/>を使う。


見出し

# sample1
## sample2
### sample3

#の数で階層を表す。


テーブル

|title|description|
|||
|sample|hogehoge|
title description
sample hogehoge


コード

```cs
Console.WriteLine("sample");
```

Console.WriteLine("sample");

csはC#だけど、ほかにもいろいろ指定可能で言語名を指定すればたいていはいける。

ちなみにインラインで書く場合はバッククォートをひとつで囲む。
`sample code`


箇条書き

通常

* sample1
* sample2
* sample3
  • sample1
  • sample2
  • sample3

連番

1. sample1  (←スペース2つ入れるとインデントされる)
hogehoge1
1. sample2
1. sample3
  1. sample1
    hogehoge1
  2. sample2
  3. sample3


リンク

通常

[Finalstream](http://www.finalstream.net/)

Finalstream

ちなみにtargetを指定して別タブ等で開くようにしたい場合はHTMLで書くしかない。
<a href="http://www.finalstream.net" target="_blank">Finalstream</a>

埋め込み

[http://www.finalstream.net/:embed]

:embedをつけるだけでいい感じに埋め込んでくれる。youtubeのurlなどもOK。


エスケープ

やりたいこと 書き方 Preview
通常 \*\*sample text\*\* **sample text**
HTML `<a href="xxx">sample text</a>` <a href="xxx">sample text</a>
バッククォート `` `sample text` `` `sample text`

バッククォートのエスケープはスペースをいれてエスケープ対象より多い連続したバッククォートで囲む。


脚注

sample text[^1]
[^1]:hogehoge

ちなみに上記の記述ははてなでは効かないのではてなでは以下のようにする。

sample text((hogehoge))

sample text*1


イメージ

![Logo](http://www.finalstream.net/images/logo/topfinalstreamlogo.png)

Logo


はてなだけ

目次

以下のコードでページの上部にあるような目次生成が可能。
[:contents]




ほかにもでてきたら追記します。

*1:hogehoge