如何在C#中获取存储过程脚本 [英] how to get the stored procedure script in the C#

查看:184
本文介绍了如何在C#中获取存储过程脚本的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

如何在C#中获取存储过程脚本


how to get the stored procedure script in the C#

SELECT text
FROM syscomments
WHERE id = (SELECT id FROM sysobjects WHERE name = 'Tablename')
ORDER BY colid



我们可以获得整个脚本,但我需要如何我们可以只使用参数脚本...我们需要在.net中调用脚本然后我们需要在现有参数中添加一些参数。



如何获取参数脚本需要在c#



中为脚本添加新参数例如:



//启动参数

@name varchar(20),







@result varchar(20)

//结束参数


we can get the whole script but i need how can we take only the parameters script... we need to call the script in .net then we need to add some parameters to that existing parameters.

how to get script of parameters and need to add new parameter to ths script in c#

eg:

//starting parametees
@name varchar(20),
.
.
.
@result varchar(20)
//ending parameters

推荐答案

意味着什么?



如何在.net中使用存储过程 [ ^ ]


从C#运行以下两个查询您将获得所需的结果

运行以下脚本您将获得st pro

Run the following two queries from C# you will get the desired result
run the following script you will get the definition of st pro
SELECT definition FROM sys.sql_modules 
WHERE [object_id] = OBJECT_ID('dbo.procedurename');



你可以得到参数通过运行此查询


and you can get the params by running this query

SELECT name, system_type_id, max_length, precision, scale
FROM sys.parameters
WHERE [object_id] = OBJECT_ID('dbo.procedurename');


private string AddColumnInStoredProcedure(String newColumn)

{

try

{

connStringForDB = ConfigurationManager.ConnectionStrings [Conv3DBConnectionString ] .ConnectionString;

sqlconn = new SqlConnection(connStringForDB);

if(sqlconn.State == 0)

sqlconn.Open( );

string strSQL =SELECT text FROM syscomments WHERE id =(SELECT id FROM sysobjects WHERE name ='InsertRequestForexcel_temp_sp') ORDER BY colid;

DataSet ds = new DataSet();

sqlconn.Open();

SqlDataAdapter da = new SqlDataAdapter(strSQL ,sqlconn);

//sqlconn.Close();

da.Fill(ds);

StringBuilder sb = new StringBuilder() ;

foreach(ds.Tables [0]中的DataRow项目.Rows)

{

string Str = item.ItemArray [0]。 ToString();

string strNew = string.Empty;

string newColumn =newCOl;

if(Str.Contains( - - (EOP)))

{

int startIndex = Str.IndexOf( - (EOP));

strNew = Str.Substring(0,startIndex)+@+ newColumn +varchar(10),+ Str.Substring(startIndex);

}

if(Str .Contains( - (ICN))&& strNew == string.Empty)

{

int startIndex = Str.IndexOf( - (ICN));

strNew = Str.Substring(0,startIndex)+, + newColumn ++ Str.Substring(startIndex); // INSERT COLUMN NAME

}

else if(strNew.Contains( - (ICN) )&& strNew!= string.Empty)

{

int startIndex = strNew.IndexOf( - (ICN));

strNew = strNew.Substring(0,startIndex)+,+ newColumn ++ strNew.Substring(startIndex); // INSERT COLUMN NAME

}

if (Str.Contains( - (ICV))&& strNew == string.Empty)

{

int startIndex = Str.IndexOf( - (ICV) ));

strNew = Str.Substring(0,startIndex)+,@+ newColumn ++ Str.Substring(startIndex); // INSERT COLUMN VALUE(PARAMETER NAME)

}

else if(strNew.Contains( - (ICV))&& strNew!= string.Empty)

{

int startIndex = strNew.IndexOf( - (ICV));

strNew = strNew.Substring(0,startIndex)+,@+ newColumn ++ strNew.Substring(startIndex) ; // INSERT COLUMN NAME

}

if(strNew!=)

{

sb。追加(strNew);

//strList.Add(strNew);

}

其他

{

sb.Append(Str);

//strList.Add(Str);

}





}



// SqlCommand cmd = new SqlCommand(sb.ToString(),sqlconn);

SqlCommand cmd = new SqlComma nd(Alter+ sb.ToString()。Substring(6),sqlconn);

cmd.ExecuteNonQuery();







}
private string AddColumnInStoredProcedure(String newColumn)
{
try
{
connStringForDB = ConfigurationManager.ConnectionStrings["Conv3DBConnectionString"].ConnectionString;
sqlconn = new SqlConnection(connStringForDB);
if (sqlconn.State == 0)
sqlconn.Open();
string strSQL = "SELECT text FROM syscomments WHERE id = (SELECT id FROM sysobjects WHERE name = 'InsertRequestForexcel_temp_sp') ORDER BY colid";
DataSet ds = new DataSet();
sqlconn.Open();
SqlDataAdapter da = new SqlDataAdapter(strSQL, sqlconn);
//sqlconn.Close();
da.Fill(ds);
StringBuilder sb = new StringBuilder();
foreach (DataRow item in ds.Tables[0].Rows)
{
string Str = item.ItemArray[0].ToString();
string strNew = string.Empty;
string newColumn = "newCOl";
if (Str.Contains("--(EOP)"))
{
int startIndex = Str.IndexOf("--(EOP)");
strNew = Str.Substring(0, startIndex) + "@" + newColumn + " varchar(10), " + Str.Substring(startIndex);
}
if (Str.Contains("--(ICN)") && strNew == string.Empty)
{
int startIndex = Str.IndexOf("--(ICN)");
strNew = Str.Substring(0, startIndex) + "," + newColumn + " " + Str.Substring(startIndex);//INSERT COLUMN NAME
}
else if (strNew.Contains("--(ICN)") && strNew != string.Empty)
{
int startIndex = strNew.IndexOf("--(ICN)");
strNew = strNew.Substring(0, startIndex) + "," + newColumn + " " + strNew.Substring(startIndex);//INSERT COLUMN NAME
}
if (Str.Contains("--(ICV)") && strNew == string.Empty)
{
int startIndex = Str.IndexOf("--(ICV)");
strNew = Str.Substring(0, startIndex) + ",@" + newColumn + " " + Str.Substring(startIndex);//INSERT COLUMN VALUE(PARAMETER NAME)
}
else if (strNew.Contains("--(ICV)") && strNew != string.Empty)
{
int startIndex = strNew.IndexOf("--(ICV)");
strNew = strNew.Substring(0, startIndex) + ",@" + newColumn + " " + strNew.Substring(startIndex);//INSERT COLUMN NAME
}
if (strNew != "")
{
sb.Append(strNew);
//strList.Add(strNew);
}
else
{
sb.Append(Str);
//strList.Add(Str);
}


}

//SqlCommand cmd = new SqlCommand(sb.ToString(),sqlconn);
SqlCommand cmd = new SqlCommand("Alter " + sb.ToString().Substring(6), sqlconn);
cmd.ExecuteNonQuery();



}


这篇关于如何在C#中获取存储过程脚本的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆