存储过程不返回 int 值
本文关键字:int 返回 存储过程 | 更新日期: 2023-09-27 18:37:24
MySql 过程代码:
CREATE DEFINER=`root`@`localhost` PROCEDURE `USP_CreateCliente`(IN nome_cliente VARCHAR(45))
BEGIN
Select 20;
INSERT INTO clienti ( nome_cliente )
VALUES ( nome_cliente );
Select id_cliente from clienti;
END
控制器页中的 C# 代码:
ClienteInfo CI = new ClienteInfo();
DboUser objdbo = new DboUser();
int id_cliente = 0;
CI.nome_cliente = txtNomeCliente.Text;
id_cliente = objdbo.CreateClienteInfo(CI);
Dbo用户类:
public int CreateClienteInfo(ClienteInfo CI)
{
int result;
MySqlConnection conn = new MySqlConnection();
DbConnection db = new DbConnection();
conn = db.ConnessioneDb();
MySqlCommand cmd = new MySqlCommand(Costanti.StoredProcedures.USP_CreateCliente, conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.AddWithValue("@nome_cliente", CI.nome_cliente);
result = cmd.ExecuteNonQuery();
conn.Close();
return result;
}
我希望我的 C# 代码在将客户 ID 插入数据库后检索该 ID,以便我可以将其保存到会话中,稍后在将打印包含客户信息的文档的页面中再次检索它。
我的id_cliente返回 0,您是否注意到任何语法错误?我做错了什么吗?
我 90% 确定这是处理存储的先验困难的问题,因为客户被正确插入
更改此行
result = cmd.ExecuteNonQuery();
自
result = Convert.ToInt32(cmd.ExecuteScalar());
但是,您还应该更改存储过程,因为它不会返回由 AUTO_INCREMENT
列生成的最后一个 ID id_cliente
CREATE DEFINER=`root`@`localhost` PROCEDURE `USP_CreateCliente`(IN nome_cliente VARCHAR(45))
BEGIN
INSERT INTO clienti ( nome_cliente ) VALUES ( nome_cliente );
Select LAST_INSERT_ID();
END
在 MySql 中,要获取生成的auto_increment值,可以使用 LAST_INSERT_ID(),接下来,您的 C# 代码不需要使用 ExecuteNonQuery,它只返回您更改、添加或删除的行数,但您使用 ExecuteScalar,它返回存储过程执行的最后一个 SELECT 命令的第一行的第一列。(它是选择LAST_INSERT_ID())
此外,要完成答案,您实际上并不需要存储过程来完成这种简单的工作。优点应该是最小的,而与要维护的不同软件相关的问题是不言而喻的。
您的 C# 代码可能是(删除了 DbConnection 类的用法,因为不清楚它的作用)
public int CreateClienteInfo(ClienteInfo CI)
{
int result;
string cmdText = @"INSERT INTO clienti ( nome_cliente ) VALUES ( nome_cliente );
Select LAST_INSERT_ID();";
using(MySqlConnection conn = new MySqlConnection(....connectionstring .....))
using(MySqlCommand cmd = new MySqlCommand(cmdText, conn);
{
conn.Open()
cmd.Parameters.AddWithValue("@nome_cliente", CI.nome_cliente);
result = Convert.ToInt32(cmd.ExecuteScalar())
return result;
}
}
在这里,您可以使用将批处理命令传递给MySql引擎的可能性,这意味着两个具有相同MySqlCommand的命令文本用分号分隔它们