From 953f04542ec9a6da12a2bbd96fc1a3e6b9d16210 Mon Sep 17 00:00:00 2001 From: David Szmolka <69192509+sfc-gh-dszmolka@users.noreply.github.com> Date: Wed, 4 Oct 2023 07:56:02 +0200 Subject: [PATCH 1/2] Update README.md with example how to bind an array as variable --- README.md | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/README.md b/README.md index 440cd0e0a..e685bde2b 100644 --- a/README.md +++ b/README.md @@ -642,6 +642,41 @@ using (IDbConnection conn = new SnowflakeDbConnection()) } ``` +Binding _an array_ As Variable +------------------------------ + +Directly binding an array to a variable is not supported currently. Instead, the usual method to pass local arrays as SQL arrays via bind is to use the SQL form `PARSE_JSON(?)`, and then pass a JSON encoded array as string to the variable `?` + +Using a stored procedure as an example, which can take an array as an input. Note, you'll need `Newtonsoft.Json` which is already a dependency of the driver. +```cs +using Snowflake.Data; +using Newtonsoft.Json; +.. + + using (IDbCommand cmd = conn.CreateCommand()) + { + + int[] vals = new int[] { 1, 2, 3 }; + string array = JsonConvert.SerializeObject(vals); + string sql = "CALL test_db.public.test(parse_json(?))"; // test SP, returns a single value + // execute this sql with bind variable 'array' + cmd.CommandText = sql; + + var p1 = cmd.CreateParameter(); + p1.ParameterName = "1"; + p1.Value = array; // passing the array in the bind variable + p1.DbType = DbType.String; + cmd.Parameters.Add(p1); + + IDataReader reader = cmd.ExecuteReader(); + while (reader.Read()) + { + Console.WriteLine(reader.GetString(0)); + } + conn.Close(); + } +```` + Close the Connection -------------------- From c7bfcc56848c2dabe4efe0f4c8472029c97c6aa8 Mon Sep 17 00:00:00 2001 From: David Szmolka <69192509+sfc-gh-dszmolka@users.noreply.github.com> Date: Mon, 8 Apr 2024 15:22:27 +0200 Subject: [PATCH 2/2] Update README.md --- README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index e685bde2b..a9cc82dfb 100644 --- a/README.md +++ b/README.md @@ -657,14 +657,14 @@ using Newtonsoft.Json; { int[] vals = new int[] { 1, 2, 3 }; - string array = JsonConvert.SerializeObject(vals); + string array = JsonConvert.SerializeObject(vals); // alternatively you can do `vals.ToArray()` when passing it to `p1.Value` string sql = "CALL test_db.public.test(parse_json(?))"; // test SP, returns a single value // execute this sql with bind variable 'array' cmd.CommandText = sql; var p1 = cmd.CreateParameter(); p1.ParameterName = "1"; - p1.Value = array; // passing the array in the bind variable + p1.Value = array; // passing the array in the bind variable. p1.DbType = DbType.String; cmd.Parameters.Add(p1);