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

NULLのcolumnを含むDBでデータを取得する/Golang

どうも、@CreatorQsFです。我が家にもやっと春が舞い戻ってまいりました。

さて、僕はもともとCとPHPとMySQLでサービス作ってた人です。そんな中で世紀末ぐらい困ったことが会ったので記しておきます。

まず、PHPでの時わたしはDB関連は全て自作していました。これでも一応SQLかけるので。
ですが、Goに変えてからgithubなどのLibraryを積極的に使うようにしています。フレームワークも今はrevelを使ってます(╹◡╹)

そして、当然のごとくgorpを使いはじめるわけなんですが…これが意外と難しい。というよりPHPの成り上がり下克上果たせなかった系Goプログラマには結構問題点が多くて。私自身にですが。

まず、DBを使うのに、structと組み合わせるためにマッピングしなきゃならない。いや正確に言うと、今まではDBから取得したらそれが自動的にオブジェクトに落とし込めていたので、なんか気にすることなかったんですな。
だけど、最近のモダンなやつ見てるとどうもそうでもないらしい。構造体を作ってそこに落としこむのが主流なのかな。

ってことで、やってみたのはいいものの…

…動かないっす先輩。
思ったとおりに行かないっす

原因は、MySQLのcolumnにNULLが含まれているためでした。そこで、sql.NullStringの存在を知ります。

で、それを

  for _, l := range list {
    p := l.(*models.A)
    fmt.Printf("%d,%t, %s\n", p.Id,p.Status,p.Url)
           
  }

こんなかんじに調理したとします。
この青四角のところが大問題なわけで、最初こう書きました。

result string = p.Url

そうすると、みんな大好き型エラー。
で、次にこう。

result string = fmt.Sprintf("%v",p.Url)

いや、動いたんですけど…。問題はそうじゃなくて、吐出されたものがめちゃめちゃに汚い。オエッの方じゃなくて。

で、なんじゃこりゃと思って、次にこう。

result string = fmt.Sprintf("%T",p.Url)

ちなみに、%Tは型を表示します。
そうして、どうも構造体っぽいやつだな、と。
で、その中でもStringにほしい値が入っていたので、こう。

result string = smt.Sprintf("%s",p.Url.String)

万事解決。多分Cとかならすぐに気づいたんでしょうけど、どうもGoにまだ体がついて行かなくて…。そういう問題じゃないかも。w

というわけで、sql.NullStringを使ったら、最後にStringをつけると綺麗に値が出力できて幸せになれるよ、というお話でした。めっちゃ初心者っぽいなw

コメント

このブログの人気の投稿

Vaffle.vimがいい感じ

実はいまのいままで、ずっとUnite.vimを使い続けてきていました。 Shougoさんのunite.vimは確かに素晴らしかったです。しかしながら、私には到底使い切れるものでもなく、もったいないとおもいつつ、ファイラーとmruのみを使う日々が続いておりました。 御存知の通り、随分前にご本人はすでにuniteからdeniteへと移行をしています。 知らなかったわけではないんですが、動いてるし速度にも問題を感じることがなかったので放置していました。 しかし今回、現状に合わせて、この部分を考え直すことにしました。要するにVimのファイラをどうしよう問題です。 で、いろいろ見た限り、わたしには、 https://github.com/cocopon/vaffle.vim これが最も適しているようでした。 ブログ記事はこちらです。 http://cocopon.me/blog/?p=6084 かなり気に入っています。動作はなかなかに速いですし、hjklで移動できる感覚も、なれると良いものですね。 あとはmruをどうしようかなーというところのみとなりました。

GoのHelloWorld!

どうも。de-liKeRというブログで普段は書いてます、 @CreatorQsF です。 知ってる人は知ってるのかな。 さて、本日より、私、GoLangの魅力に触れて感動したので、作っているプロジェクトとwebアプリをPHPからGoへ移行することを宣言いたします。 構文と仕様はいろんなところのを引っ張ってきた感じで、その際にCを学んだ時みたいにアウトプットする場がほしいので、こうして作りました。 よろしくお願いします。 さてさて、ではインストールから説明。 how to install go lang on mac? 説明ってほどでもないです。 普通にHomebrewで、 brew install go sudo install Mercurial を叩いてください。(MercurialはなんかGoに必要らしいです。) で、bash_profileでもなんでもいいのでパスを通しまーす export GOROOT=`go env GOROOT` export GOPATH=$HOME/ ホーム以下好きなディレクトリを指定し給え。 export PATH=$PATH:$GOROOT/bin:$GOPATH/bin でこれでインストール自体は終わり。あとでRevelについては書きますのでとりあえず動くかどうかだけ。 テキトウなところに、test.goってファイルを作ります。 中身こんなかんじで書いて下さい package main import fmt "fmt" func main() {   fmt.Print("Hello World!") } これで終わり。めっちゃ簡単♪ であとはTerminalから cd test.goがあるディレクトリ go run test.go でほんとに、めっちゃ高速で結果が表示されます。スクリプト言語並みです。 ってなもんです。質問あったら是非おきがるにHangoutかGoogle+へどうぞ。

GoでPodcast用のサーバーを組むときに良い(良さそうな)lib

いい感じのライブラリ、あります。 現在作成中のPadio(仮名)というサービスではこれを使っています(が、しかしもしかしたら変えるかも。現状はすごい満足)。 https://github.com/eduncan911/podcast https://godoc.org/github.com/eduncan911/podcast