2014年1月9日木曜日

開発環境

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

その他参考書籍

15.11(練習問題)、2-b.

コード(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 "州/準州と州/準州都の人口"
    r <- quickQuery' conn ("SELECT Density.Population, Capitals.Population " ++
                           "FROM Density INNER JOIN Capitals " ++
                           "WHERE Density.State == Capitals.State") []
    mapM_ putStrLn $ map (\(a:b:[]) -> a ++ ", " ++ b) $
          map (\x -> map (\y -> fromSql y :: String) x) r
    disconnect conn

入出力結果(Terminal, runghc)

$ runghc Sample.hs
州/準州と州/準州都の人口
512930, 172918
135294, 58358
908007, 359183
729498, 81346
7237479, 682757
11410046, 46828979
1119583, 671274
978933, 192800
2974807, 937845
3907738, 311902
28674, 21405
37360, 16541
26745, 5236
$

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

0 コメント:

コメントを投稿