对insert语句执行标量

时间:2011-07-14 12:04:53

标签: asp.net sql

我正在尝试通过我的asp.net网站获取我已​​插入数据库表的最后一条记录的id 我的插入语句是一个存储过程,我尝试过使用标量函数,但它给了我这个指定的强制转换是无效的。

这是我正在使用的插入语句:

@ClientID varchar(250),
@BType varchar(250),
@CIP varchar(50),
@Sess varchar(500),
@LoggedIn int,
@LoggedInTime datetime

AS
BEGIN
    INSERT INTO tblSession ( ClientID, BType, CIP, Sess, LoggedIn, LoggedInTime) VALUES ( @ClientID, @BType, @CP,@Sess, @LoggedIn, @LoggedInTime) 
    SELECT SCOPE_IDENTITY()
END

我正在调用的方法:

 using (SqlConnection con = DBConnection.getConnection())
 {
    string sql = "Add";
    SqlCommand command = new SqlCommand(sql, con);
    command.CommandType = CommandType.StoredProcedure;

    command.Parameters.Add("@ClientID ", SqlDbType.VarChar).Value = id;
    command.Parameters.Add("@BType", SqlDbType.VarChar).Value = bt;
    command.Parameters.Add("@CIP", SqlDbType.VarChar).Value = cip;
    command.Parameters.Add("@Sess", SqlDbType.VarChar).Value = s;
    command.Parameters.Add("@LoggedIn", SqlDbType.Int).Value = LoggedIn;
    command.Parameters.Add("@LoggedInTime", SqlDbType.DateTime).Value = session.LoggedInTime;

    int x;
    x = (int)command.ExecuteScalar();
    return x;
 }

请任何帮助非常适合它

3 个答案:

答案 0 :(得分:1)

在存储过程和C#代码中创建一个输出参数,然后只执行executeNonQuery

答案 1 :(得分:0)

我发现example on MSDN我认为可以帮助你,因为它似乎可以解决像你这样的情况。在示例中,它只使用查询而不是存储过程,但也许可以提供帮助。如果没有要返回的内容,标量查询始终返回值或NULL。你确定你的插件工作正常吗?也许它返回NULL因为你的插入失败了。

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;
}

答案 2 :(得分:-1)

我绝对不确定我是否理解你的问题,但电话应该是

command.ExecuteNonQuery();