私はSqliteで遊んでいて、いくつかのテストデータを読み戻そうとするとエラーが発生し続けます。たとえば、次のように、単一のテーブルといくつかの列を持つ単純なdbを作成し、いくつかのテストデータを入力しました。
sqlite> .schema
CREATE TABLE "shows"(id integer primary key asc autoincrement, showName TEXT, guest TEXT, dateAired date, dateWatched date);
sqlite> select * from shows;
6|test show|test guest 1|2012.05.01|2012.07.10
7|test show|test guest 2|2012.05.02|2012.07.10
8|test show|test guest 4|2012.05.04|2012.07.10
ここで利用できるSystem.Data.Sqliteライブラリを使用していますが、日付列を読み取ろうとするとエラーが発生し続けます。日付をdd-MM-yyyy形式で入力しようとしましたが、「文字列が有効な日時として認識されていません」というエラーが表示されます。DateTime.Parseを使用するか、datetimeにキャストするか、ToString()を実行して何が起こるかを確認しようとしましたが、同じエラーが発生し続けます。テキストフィールドは正常に読み取ることができますが、日付フィールドは読み取ることができません。
切り取ったC#コードを以下に示します
var sqliteConn = new SQLiteConnection("Data Source=data/shows.db;Version=3;New=False;Compress=True");
sqliteConn.Open();
SQLiteCommand cmd = new SQLiteCommand(sqliteConn);
cmd.CommandText = "select * from shows";
SQLiteDataReader reader = cmd.ExecuteReader( );
while (reader.Read( ))
{
var showName = reader["showName"];
// This is where it keeps giving me an error.
// I have tried various things such as DateTime.Parse
var airedDate = DateTime.ParseExact("yyyy.MM.dd", reader["dateAired"].ToString(), new CultureInfo("en-AU"));
}
reader.Close( );
どんな助けでも大歓迎です。
よろしく、