開発環境
- OS X Mavericks - Apple(OS)
- BBEdit - Bare Bones Software, Inc., Emacs (Text Editor)
- Haskell (純粋関数型プログラミング言語)
- GHC (The Glasgow Haskell Compiler) (処理系)
- The Haskell Platform (インストール方法、モジュール等)
初めてのコンピュータサイエンス(Jennifer Campbell、Paul Gries、Jason Montojo、Greg Wilson(著)長尾 高弘(翻訳))の15章(データベース)、15.11(練習問題)、1-i.をHaskellで解いてみる。
その他参考書籍
- プログラミングHaskell (オーム社) Graham Hutton(著) 山本 和彦(翻訳)
- Real World Haskell―実戦で学ぶ関数型言語プログラミング (オライリージャパン) Bryan O'Sullivan John Goerzen Don Stewart(著) 山下 伸夫 伊東 勝利 株式会社タイムインターメディア(翻訳)
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 コメント:
コメントを投稿