Pass parameters correctly to SqlCommand(将参数正确传递给 SqlCommand)
本文介绍了将参数正确传递给 SqlCommand的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有将数据插入 SQL 表的代码.这些列有这样的类型:
I have code to insert data to SQL table. The columns have such types:
@param1 datetime,
@param2 nvarchar(50),
@param3 int,
@param4 bit,
@param5 int,
@param6 bit,
@param7 bit,
@param8 varchar(20),
@param9 varchar(20)
这是我的方法:
try
{
using (SqlCommand oleDbCommand = new SqlCommand())
{
// Set the command object properties
oleDbCommand.Connection = new SqlConnection(connectionString);
oleDbCommand.CommandType = CommandType.StoredProcedure;
oleDbCommand.CommandText = "[dbo].[InsertRow]";
// Add the input parameters to the parameter collection
// m.param1 is of DateTime type, m.param2 of string type, m.param3 of int type, etc.
oleDbCommand.Parameters.AddWithValue("@param1", m.param1);
oleDbCommand.Parameters.AddWithValue("@param2", m.param2);
oleDbCommand.Parameters.AddWithValue("@param3", m.param3);
oleDbCommand.Parameters.AddWithValue("@param4", m.param4);
oleDbCommand.Parameters.AddWithValue("@param5", m.param5);
oleDbCommand.Parameters.AddWithValue("@param6", m.param6);
oleDbCommand.Parameters.AddWithValue("@param7", m.param7);
oleDbCommand.Parameters.AddWithValue("@param8", m.param8);
oleDbCommand.Parameters.AddWithValue("@param9", m.param9);
// Open the connection, execute the query and close the connection.
oleDbCommand.Connection.Open();
oleDbCommand.ExecuteNonQuery();
oleDbCommand.Connection.Close();
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
return false;
}
我有两个相关的问题:
- 我是否正确传递参数?还是我需要演员表?(请参阅中的列类型问题的开头).
- 如何正确处理关闭数据库?如果还有一些例外情况?
推荐答案
我会这样做
try
{
using (var conn = new SqlConnection(connectionString))
using (var command = new SqlCommand("[dbo].[InsertRow]", conn) {
CommandType = CommandType.StoredProcedure }) {
conn.Open();
command.Parameters.Add("@param1", SqlDbType.DateTime).Value = m.param1;
command.Parameters.Add("@param2", SqlDbType.NVarChar, 50).Value = m.param2;
command.Parameters.Add("@param3", SqlDbType.Int).Value = m.param3;
command.Parameters.Add("@param4", SqlDbType.Bit).Value = m.param4;
command.Parameters.Add("@param5", SqlDbType.Int).Value = m.param5;
command.Parameters.Add("@param6", SqlDbType.Bit).Value = m.param6;
command.Parameters.Add("@param7", SqlDbType.Bit).Value = m.param7;
command.Parameters.Add("@param8", SqlDbType.VarChar, 20).Value = m.param8;
command.Parameters.Add("@param9", SqlDbType.VarChar, 20).Value = m.param9;
command.ExecuteNonQuery();
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
return false;
}
这篇关于将参数正确传递给 SqlCommand的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:将参数正确传递给 SqlCommand
猜你喜欢
- 在 C# 中异步处理项目队列 2022-01-01
- 在 LINQ to SQL 中使用 contains() 2022-01-01
- Azure Active Directory 与 MVC,客户端和资源标识同一 2022-01-01
- Windows 喜欢在 LINUX 中使用 MONO 进行服务开发? 2022-01-01
- 带问号的 nvarchar 列结果 2022-01-01
- 是否可以在 .Net 3.5 中进行通用控件? 2022-01-01
- 使用 rss + c# 2022-01-01
- CanBeNull和ReSharper-将其用于异步任务? 2022-01-01
- 为什么 C# 中的堆栈大小正好是 1 MB? 2022-01-01
- C# 通过连接字符串检索正确的 DbConnection 对象 2022-01-01