let useConnection expr =
let Expr(conn : MySqlConnection) =
try
try
conn.Open()
with
| :? MySqlException as ex
-> printfn "Exception! %s" ex.Message
expr(conn)
finally
try
conn.Close() |> ignore
with
| :? MySqlException as ex
-> printfn "Exception! %s" ex.Message
using (new MySqlConnection(ConnectionString =
"server = " + MySQLServer + ";
uid = " + MySQLUID + ";
pwd = " + MySQLPW + ";
database = " + MySQLDB + ";
Charset=utf8;")) Expr
member x.reportToDB (msg:string) =
useConnection // <--- SO HERE I WANT TO KNOW WHAT IS conn
(let cmd = new MySqlCommand(Connection = conn)
cmd.CommandText <- ("insert into "+MySQLTable+"(system,dt,logMessage);")
ignore <| cmd.Parameters.AddWithValue("?system", Net.Dns.GetHostName())
ignore <| cmd.Parameters.AddWithValue("?dt", DateTime.Now.ToString())
ignore <| cmd.Parameters.AddWithValue("?logMessage", msg)
try
try
cmd.ExecuteNonQuery() |> ignore
with
| :? MySqlException as ex when ex.Message.Contains("Duplicate entry")
-> printfn "MySQL Duplicate entry Exception: discarding the data set! %s" ex.Message
printfn ""
| :? MySqlException as ex
-> printfn "MySQL Exception, requeing data set and trying again later! %s" ex.Message
reraise()
with
| :? MySqlException as ex
-> printfn "Exception! %s" ex.Message)
説明するのは難しいですが、useConnectionからdelegate connをx.reportToDBに使用したいのですが、どうすればいいですか?Exprの使用法からのパラメータの使い方
ありがとうございました。
@Tim Robinson、はい私はそこにconnについて知りません。それは解決したい問題です。 ラムダはここでは悪い考えですか?
それは現時点ではコンパイルのようにこのコードは見ていません - I最初の行はインデントされていなければならず、コメント後のコードはラムダ関数である必要があります –
lambaは素晴らしいアイディアです:)あなたは現在1つを使用していません。 –