質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Haskell

Haskellは高い機能性をもった関数型プログラミング言語で、他の手続き型プログラミング言語では難しいとされている関数でも容易に行うことができます。強い静的型付け、遅延評価などに対応しています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

Q&A

解決済

2回答

1726閲覧

mysql-haskellでMySQLDateTimeに引数が渡せない

apo

総合スコア362

Haskell

Haskellは高い機能性をもった関数型プログラミング言語で、他の手続き型プログラミング言語では難しいとされている関数でも容易に行うことができます。強い静的型付け、遅延評価などに対応しています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

0グッド

0クリップ

投稿2020/06/05 00:29

MySQL(MariaDB)にInsertしたいがMySQLDateTimeに引数が渡せない

HaskellでMySQLにInsertを実行したいがエラーになります。
型があっていないようですが、どのように記述したらよいのかわかりません。

発生している問題・エラーメッセージ

apo@debian:~/doc/project/make/haskell/mysql-haskell/my-project$ stack build my-project-0.1.0.0: unregistering (local file changes: app/Main.hs) my-project> configure (lib + exe) Configuring my-project-0.1.0.0... my-project> build (lib + exe) Preprocessing library for my-project-0.1.0.0.. Building library for my-project-0.1.0.0.. Preprocessing executable 'my-project-exe' for my-project-0.1.0.0.. Building executable 'my-project-exe' for my-project-0.1.0.0.. [2 of 2] Compiling Main /home/apo/doc/project/make/haskell/mysql-haskell/my-project/app/Main.hs:24:86: error: parse error on input ‘2020’ | 24 | executeStmt conn stmt [MySQLText "chris", MySQLText "comment", MySQLDateTime '2020/06/05 09:00:00'] | ^^^^ -- While building package my-project-0.1.0.0 using: /home/apo/.stack/setup-exe-cache/x86_64-linux-tinfo6/Cabal-simple_mPHDZzAJ_2.0.1.0_ghc-8.2.2 --builddir=.stack-work/dist/x86_64-linux-tinfo6/Cabal-2.0.1.0 build lib:my-project exe:my-project-exe --ghc-options " -fdiagnostics-color=always" Process exited with code: ExitFailure 1

該当のソースコード

Haskell

1{-# LANGUAGE OverloadedStrings #-} 2 3module Main where 4 5import Lib 6import Control.Exception 7import Database.MySQL.Base 8import qualified System.IO.Streams as Streams 9 10transactional :: MySQLConn -> IO a -> IO a 11transactional conn procedure = mask $ \restore -> do 12 execute_ conn "BEGIN" 13 a <- restore procedure `onException` (execute_ conn "ROLLBACK") 14 execute_ conn "COMMIT" 15 pure a 16 17main :: IO () 18main = do 19 someFunc 20 conn <- connect 21 defaultConnectInfo {ciUser = "root", ciPassword = "password", ciDatabase = "test"} 22 stmt <- prepareStmt conn "INSERT INTO memos (name, comment, time) VALUES (?, ?, ?)" 23 transactional conn $ do 24 executeStmt conn stmt [MySQLText "chris", MySQLText "comment", MySQLDateTime '2020/06/05 09:00:00']

試したこと

時刻の記載の仕方が悪いと思い、色々試してみましたがだめでした。

executeStmt conn stmt [MySQLText "chris", MySQLText "comment", MySQLDateTime '2020-06-05 09:00:00'] executeStmt conn stmt [MySQLText "chris", MySQLText "comment", MySQLDateTime '2020-06-05 09:00:00.000001'] executeStmt conn stmt [MySQLText "chris", MySQLText "comment", MySQLDateTime '2020/06/05 09:00:00'] executeStmt conn stmt [MySQLText "chris", MySQLText "comment", MySQLDateTime '06/05/2020 09:00:00'] executeStmt conn stmt [MySQLText "chris", MySQLText "comment", MySQLDateTime '06-05-2020 09:00:00']

補足情報(FW/ツールのバージョンなど)

OS:Debian10
DataBase:mysql Ver 15.1 Distrib 10.3.22-MariaDB, for debian-linux-gnu (x86_64) using readline 5.2
Stack:Version 2.3.1
Resolver:lts-11.22
テーブルの定義

MariaDB [test]> show columns from memos; +---------+--------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +---------+--------------+------+-----+---------+----------------+ | id | mediumint(9) | NO | PRI | NULL | auto_increment | | name | char(30) | YES | | NULL | | | comment | char(50) | YES | | NULL | | | time | datetime | YES | | NULL | | +---------+--------------+------+-----+---------+----------------+

全てのソースコード
https://github.com/ringo-apo/mysql-haskell
参考にしたサイト
https://qiita.com/lotz/items/1d9c7b4333fd4d29a150

よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

こんにちは。
とりあえず問題の箇所についてぱっと見回答です。

まず最初に、値をシングルクオートでくくってるのが完全におかしいですが、それは置いといて、
ドキュメントを眺めた限り、MySQLDateTimeLocalTime を渡して作ると言っています。
https://hackage.haskell.org/package/mysql-haskell-0.8.4.2/docs/Database-MySQL-Protocol-MySQLValue.html
https://hackage.haskell.org/package/time-1.8.0.2/docs/Data-Time-LocalTime.html

そして、LocalTime はいろいろ方法はありそうですがとりあえず parseTimeM で String から作れそうですね。
https://hackage.haskell.org/package/time-1.8.0.2/docs/Data-Time-Format.html

投稿2020/06/05 01:32

tamoto

総合スコア4252

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

apo

2020/06/05 02:58

ありがとうございます。試してみます。
guest

0

自己解決

executeStmt conn stmt [MySQLText "chris", MySQLText "comment", MySQLText "2020/10/01 00:00:00"]

でとりあえず動きました。

投稿2020/06/10 04:32

編集2020/06/10 04:37
apo

総合スコア362

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問