我怎样才能确定一个SQL Server存储过程的参数有一个默认的?存储过程、有一个、参数、SQL

2023-09-04 00:53:57 作者:美是姐的本性

有没有一种方法,以编程方式确定是否一个SQL Server存储过程的参数有一个默认的? (奖励积分,如果你能确定哪些默认)。SqlCommandBuilder.DeriveParameters()甚至没有尝试。

Is there a way to determine programmatically if a SQL Server stored procedure parameter has a default? (Bonus points if you can determine what the default is.) SqlCommandBuilder.DeriveParameters() doesn't even try.

在此先感谢您的帮助!

编辑:我真的不关心,如果它是一个SQL查询,一个SMO对象等

I honestly don't care if it's a SQL Query, an SMO object, etc.

推荐答案

我发现使用SMO的方式:

I found a way using SMO:

Server srv; 
srv = new Server("ServerName"); 

Database db; 
db = srv.Databases["MyDatabase"]; 

var Params = db.StoredProcedures["MyStoredProc"].Parameters;

foreach(StoredProcedureParameter param in Params) {
    Console.WriteLine(param.Name + "-" + param.DefaultValue);
}