2014年1月17日金曜日

開発環境

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

その他参考書籍

15.11(練習問題)、3.

コード(BBEdit)

Sample.hs

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

import Database.HDBC
import Database.HDBC.Sqlite3

main :: IO ()
main = do
    conn <- connectSqlite3 "sample15.3.db"
    _ <- run conn "DROP TABLE Numbers" []
    _ <- run conn "CREATE TABLE Numbers (Val INTEGER)" []
    _ <- run conn "INSERT INTO Numbers Values(1)" []
    _ <- run conn "INSERT INTO Numbers Values(2)" []
    commit conn
    r1 <- quickQuery' conn "SELECT * FROM Numbers WHERE 1/0" []
    print r1
    r2 <- quickQuery' conn "SELECT * FROM Numbers WHERE 1/0 AND Val > 0" []
    print r2
    r3 <- quickQuery' conn "SELECT * FROM Numbers WHERE Val >0 AND 1/0" []
    print r3
    disconnect conn

入出力結果(Terminal, runghc)

$ runghc Sample.hs
[]
[]
[]
$

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

0 コメント:

コメントを投稿