2014年1月4日土曜日

開発環境

初めてのコンピュータサイエンス(Jennifer CampbellPaul GriesJason MontojoGreg Wilson(著)長尾 高弘(翻訳))の15章(データベース)、15.11(練習問題)、1-g.をHaskellで解いてみる。

その他参考書籍

15.11(練習問題)、1-g.

コード(BBEdit)

Sample.hs

{-# OPTIONS -Wall -Werror #-}
module Main where

import Database.HDBC
import Database.HDBC.Sqlite3

main :: IO ()
main = do
    conn <- connectSqlite3 "census.db"
    r <- quickQuery' conn
                     ("SELECT State FROM Density " ++
                      "WHERE Population < 1000000 OR 5000000 < Population") []
    putStrLn "人口が100万人未満か500万人より多い州"
    mapM_ putStrLn $ map (fromSql . head) r
    putStrLn "データ(州/準州, 人口, 面積)"
    r' <- quickQuery' conn "SELECT * FROM Density" []
    mapM_ putStrLn $ map (\(a:b:c:[]) -> a ++ ", " ++ b ++ ", " ++ c) $
                         map (\x -> map (\y -> fromSql y :: String) x) r'
    disconnect conn

入出力結果(Terminal, runghc)

$ runghc Sample.hs
人口が100万人未満か500万人より多い州
ニューファンドランド・ラブラドール州
プリンスエドワードアイランド州
ノバスコシア州
ニューブランズウィック州
ケベック州
オンタリオ州
サスカチュワン州
ユーコン準州
ノースウェスト準州
ヌナブト準州
データ(州/準州, 人口, 面積)
ニューファンドランド・ラブラドール州, 512930, 370501.69
プリンスエドワードアイランド州, 135294, 5684.39
ノバスコシア州, 908007, 52917.43
ニューブランズウィック州, 729498, 71355.67
ケベック州, 7237479, 1357743.08
オンタリオ州, 11410046, 907655.59
マニトバ州, 1119583, 551937.87
サスカチュワン州, 978933, 586561.35
アルバータ州, 2974807, 639987.12
ブリティッシュコロンビア州, 3907738, 926492.48
ユーコン準州, 28674, 474706.97
ノースウェスト準州, 37360, 1141108.37
ヌナブト準州, 26745, 1925460.18
$

慣れるまでは{-# OPTIONS -Wall -Werror #-}の記述を消さずに細かく型を指定していくことに。

0 コメント:

コメントを投稿