2014年1月16日木曜日

開発環境

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

その他参考書籍

15.11(練習問題)、2-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"
    putStrLn "人口密度の差が0.5人/km^2以下の州の組合せ"
    r <- quickQuery' conn
                     ("SELECT A.State, B.State " ++
                      "FROM Density A INNER JOIN Density B " ++
                      "WHERE A.State < B.State " ++
                      "AND (ABS (A.Population / A.Area - " ++
                                "B.Population / B.Area) < 0.5)") []
    mapM_ putStrLn $ map (\(a:b:[]) -> fromSql a ++ ", " ++ fromSql b) r
    disconnect conn

入出力結果(Terminal, runghc)

$ runghc Sample.hs
人口密度の差が0.5人/km^2以下の州の組合せ
サスカチュワン州, ニューファンドランド・ラブラドール州
サスカチュワン州, マニトバ州
アルバータ州, ブリティッシュコロンビア州
ノースウェスト準州, ユーコン準州
ヌナブト準州, ユーコン準州
ヌナブト準州, ノースウェスト準州
$

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

0 コメント:

コメントを投稿