2014年1月6日月曜日

開発環境

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

その他参考書籍

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

コード(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, Population FROM Density " ++
                      "WHERE Area > 200000") []
    putStrLn "面積が20万km^2よりも大きい州の人口'"
    mapM_ putStrLn $ map (\(a:b:[]) -> (fromSql a ++ ", " ++ fromSql b)) r
    r' <- quickQuery' conn "SELECT * FROM Density" []
    putStrLn "データ(州/準州、人口、面積)"
    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
面積が20万km^2よりも大きい州の人口'
ニューファンドランド・ラブラドール州, 512930
ケベック州, 7237479
オンタリオ州, 11410046
マニトバ州, 1119583
サスカチュワン州, 978933
アルバータ州, 2974807
ブリティッシュコロンビア州, 3907738
ユーコン準州, 28674
ノースウェスト準州, 37360
ヌナブト準州, 26745
データ(州/準州、人口、面積)
ニューファンドランド・ラブラドール州, 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 コメント:

コメントを投稿