我有以下c#代码来调用存储过程testproc
,但是当我运行此应用程序时,它说它无法找到存储过程testproc。
这是我调用存储过程的c#代码:
SqlConnection con = new SqlConnection();
con.ConnectionString = "data source='example.com';user id='sa';password='password';persist security info=False;initial catalog=Test;Connect Timeout=100; Min Pool Size=100; Max Pool Size=500";
con.Open();
DataSet ds = new DataSet();
SqlCommand com = new SqlCommand("testproc",con );
SqlDataAdapter sqlda = new SqlDataAdapter(com);
//sqlda.SelectCommand.CommandText = "SELECT Id,Name1,ZipCode,StreetName,StreetNumber,State1,Lat,Lng,Keyword, ( 6371 * ACOS( COS( (12.925432/57.2958) ) * COS( (Lat/57.2958) ) * COS( ( Lng/57.2958 ) - (77.5940171/57.2958) ) + SIN( 12.925432/57.2958 ) * SIN( Lat/57.2958 ) ) ) AS distance FROM Business_Details where( (StreetName like '%jayanagar%')and (Keyword like '%plumbing%' ))ORDER BY distance;";
//sqlda.CommandText = "select * from business where(( distance<'" + radius + "' )and (StreetName like '%" + streetname + "%')and (Keyword like '%" + keyword1 + "%' )) order by distance";
//com.CommandText = "testproc ";
com.CommandType = CommandType.StoredProcedure;
com.Parameters.Add(new SqlParameter("@lat1",SqlDbType.Float,50,lat1));
com.Parameters.Add(new SqlParameter("@lng1",SqlDbType.Float,50,lng1));
com.Parameters.Add(new SqlParameter("@radius1",SqlDbType.Int,10,radius1));
com.Parameters.Add(new SqlParameter("@streetname", SqlDbType.VarChar, 50, streetname));
com.Parameters.Add(new SqlParameter("@keyword1", SqlDbType.VarChar, 50, keyword1));
com.Parameters[0].Value = lat1;
com.Parameters[1].Value = lng1;
com.Parameters[2].Value = radius1;
com.Parameters[3].Value = streetname;
com.Parameters[4].Value = keyword1;
try
{
sqlda.Fill(ds);
con.Close();
}
catch (Exception e)
{
con.Close();
}
这是我在sql server中编写的存储过程。它在SQL server
中成功运行USE [Test]
GO
/****** Object: StoredProcedure [dbo].[tesproc] Script Date: 09/01/2010 13:00:54 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE [dbo].[tesproc]
-- Add the parameters for the stored procedure here
@a float, @b float, @d int,@s varchar(50),@k varchar(50)
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
-- Insert statements for procedure here
select Id, Name1,ZipCode,StreetName,StreetNumber,State1,Lat,Lng , ( 6371 * ACOS( COS( (@a/57.2958) ) * COS( (Lat/57.2958) ) * COS( ( Lng/57.2958 ) - (@b /57.2958) ) + SIN( @a/57.2958 ) * SIN( Lat/57.2958 ) ) ) as distance from business_details where (( 6371 * ACOS( COS( (@a/57.2958) ) * COS( (Lat/57.2958) ) * COS( ( Lng/57.2958 ) - (@b /57.2958) ) + SIN( @a/57.2958 ) * SIN( Lat/57.2958 ) ) )<@d and StreetName like '%'+ @s + '%' and Keyword like '%'+ @k +'%')
END
答案 0 :(得分:6)
您的ALTER语句将其称为tesproc
,但您的SQL命令将其称为testproc
答案 1 :(得分:5)
检查您的拼写,您的程序称为
[dbo].[tesproc]
并且您的代码正在调用
SqlCommand("testproc",con );
您还可以使用
添加参数Parameters.AddWithValue(string parameterName, Object value)
如果你想:)
答案 2 :(得分:3)
而不是这个庞大的代码
com.CommandType = CommandType.StoredProcedure;
com.Parameters.Add(new SqlParameter("@lat1",SqlDbType.Float,50,lat1));
com.Parameters.Add(new SqlParameter("@lng1",SqlDbType.Float,50,lng1));
com.Parameters.Add(new SqlParameter("@radius1",SqlDbType.Int,10,radius1));
com.Parameters.Add(new SqlParameter("@streetname", SqlDbType.VarChar, 50, streetname));
com.Parameters.Add(new SqlParameter("@keyword1", SqlDbType.VarChar, 50, keyword1));
com.Parameters[0].Value = lat1;
com.Parameters[1].Value = lng1;
com.Parameters[2].Value = radius1;
com.Parameters[3].Value = streetname;
com.Parameters[4].Value = keyword1;
您将再次为参数赋值
使用AddWithValue
方法将参数添加到命令
com.Parameters.AddWithValue("@lat1", lat1));
com.Parameters.AddWithValue("@lng1", lng1));
com.Parameters.AddWithValue("@radius1", radius1));
com.Parameters.AddWithValue("@streetname", streetname));
com.Parameters.AddWithValue("@keyword1", keyword1));
答案 3 :(得分:3)
无论如何,您的代码应如下所示:
using (SqlConnection connection = new SqlConnection(connectionString))
using (SqlComamnd command = connection.CreateCommand())
{
command.CommandText = commandText;
command.CommandType = CommandType.StoredProcedure;
command.Parameters.Add("@lat1", SqlDbType.Float,50, lat1).Value = lat1;
command.Parameters.Add("@lng1", SqlDbType.Float,50, lng1).Value = lng1;
command.Parameters.Add("@radius1", SqlDbType.Int,10, radius1).Value = radius1;
command.Parameters.Add("@streetname", SqlDbType.VarChar, 50, streetname).Value = streetname;
command.Parameters.Add("@keyword1", SqlDbType.VarChar, 50, keyword1).Value = keyword1;
connection .Open();
DataSet ds = new DataSet();
using (SqlDataAdapter adapter = neq SqlDataAdapter(command))
{
adapter.Fill(ds);
}
}