Как выполнить T-SQL из C #? - PullRequest
       47

Как выполнить T-SQL из C #?

0 голосов
/ 11 августа 2009

Кто-нибудь может привести пример выполнения оператора T-SQL с использованием C #?

Ответы [ 3 ]

10 голосов
/ 11 августа 2009

Вы имеете в виду что-то вроде этого:

private static void ReadOrderData(string connectionString)
{
      string commandText = "SELECT OrderID, CustomerID FROM dbo.Orders;";
      using (SqlConnection connection = new SqlConnection(connectionString))
      {
            using (SqlCommand command = new SqlCommand(commandText, connection))
            {
                  connection.Open();
                  using (SqlDataReader reader = command.ExecuteReader())
                  {
                        while (reader.Read())
                        {
                              Console.WriteLine(String.Format("{0}, {1}", 
                                reader[0], reader[1]));
                        }
                  }
            }
      }
}

Или, может быть, что-то вроде:

static public int AddProductCategory(string newName, string connString)
{
    Int32 newProdID = 0;
    string sql =
        "INSERT INTO Production.ProductCategory (Name) VALUES (@Name); "
        + "SELECT CAST(scope_identity() AS int)";
    using (SqlConnection conn = new SqlConnection(connString))
    {
        SqlCommand cmd = new SqlCommand(sql, conn);
        cmd.Parameters.Add("@Name", SqlDbType.VarChar);
        cmd.Parameters["@Name"].Value = newName;
        try
        {
            conn.Open();
            newProdID = (Int32)cmd.ExecuteScalar();
        }
        catch (Exception ex)
        {
            Console.WriteLine(ex.Message);
        }
    }
    return (int)newProdID;
}

Источник: MSDN

6 голосов
/ 11 августа 2009

Я предлагаю вам начать с ADO.NET-туориала, подобного этому

http://www.csharp -station.com / Учебники / AdoDotNet / Lesson01.aspx

Как использовать SQLCommand

http://www.csharp -station.com / Учебники / AdoDotNet / Lesson03.aspx

0 голосов
/ 11 августа 2009

Использование ридера:

SqlConnection MSSQLConn = new SqlConnection("your connection string");
MSSQLConn.Open();
SqlCommand MSSQLSelectConsignment = new SqlCommand();
MSSQLSelectConsignment.CommandText = "select * from yourtable where blah = @blah";
MSSQLSelectConsignment.Parameters.AddWithValue("@blah", somestring);
MSSQLSelectConsignment.Connection = MSSQLConnOLD;
SqlDataReader reader = MSSQLSelectConsignment.ExecuteReader();

while (reader.Read())
{
...
}

Чтобы вернуть одно значение:

MSSQLSelectConsignment.CommandText = "select fieldname from yourtable where blah = @blah";
string yourstring = MSSQLSelectConsignment.ExecuteScalar().ToString();

или чтобы вернуть количество строк, затронутых обновлениями и т.д .:

MSSQLSelectConsignment.CommandText = "update yourtable set yourfield = 0 where blah = @blah";
int yourint = MSSQLSelectConsignment.ExecuteNonQuery();

Надежда помогает:)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...