我有一个问题,我正在努力从这个数据访问层创建一个 WCF 服务应用程序:
public class DataAccess
{
private SqlConnection connection = new SqlConnection("Data Source=LAPI;Initial Catalog=PrimierData;Integrated Security=True");
private SqlDataReader dataReader;
private SqlCommand command;
private SqlTransaction transaction = null;
private SqlParameter[] parameters = null;
#region Conenction
public void Open()
{
if (connection.State != ConnectionState.Open)
connection.Open();
}
public void Close()
{
if (connection.State != ConnectionState.Closed)
connection.Close();
}
#endregion
#region Reader
/// <summary>
/// Executes the reader. For MultiRow Search
/// </summary>
/// <param name="commandType">Type of the command.</param>
/// <param name="commandText">The command text.</param>
/// <returns></returns>
public SqlDataReader ExecuteReader(CommandType commandType, string commandText,SqlParameter[] readerparams)
{
Open();
command = new SqlCommand(commandText, connection);
command.CommandType = commandType;
if (readerparams != null)
{
command.Parameters.AddRange(readerparams);
}
this.dataReader = command.ExecuteReader();
command.Parameters.Clear();
// Close();
return this.dataReader;
}
#endregion
#region Execute
/// <summary>
/// Executes the non query. For Insert, Update and Delete
/// </summary>
/// <param name="commandType">Type of the command.</param>
/// <param name="commandText">The command text.</param>
/// <param name="parameters">The parameters.</param>
/// <returns></returns>
public int ExecuteNonQuery(CommandType commandType, string commandText,SqlParameter[] nonparams)
{
Open();
command = new SqlCommand(commandText, connection);
command.CommandType = commandType;
command.Parameters.AddRange(nonparams);
int returnValue = command.ExecuteNonQuery();
command.Parameters.Clear();
Close();
return returnValue;
}
#endregion
}
我想使用 WCF,但出现错误
添加服务失败。服务元数据可能无法访问。确保您的服务正在运行并公开元数据。
我试图对其进行编码,但我失败了。我正在使用的代码有效,但是在创建 WCF 时,我是一个完整的菜鸟。
[ServiceContract]
public interface IService1
{
// TODO: Add your service operations here
[OperationContract]
void Open();
[OperationContract]
void Close();
[OperationContract]
SqlDataReader ExecuteReader(CommandType commandType, string commandText, SqlParameter[] readerparams);
[OperationContract]
int ExecuteNonQuery(CommandType commandType, string commandText, SqlParameter[] nonparams);
}
和我的 Service.svc
public class Service1 : IService1
{
private SqlConnection connection = new SqlConnection("Data Source=LAPI;Initial Catalog=PrimierData;Integrated Security=True");
private SqlDataReader dataReader;
private SqlCommand command;
private SqlTransaction transaction = null;
private SqlParameter[] parameters = null;
[OperationContract]
public void Open()
{
if (connection.State != ConnectionState.Open)
connection.Open();
}
[OperationContract]
public void Close()
{
if (connection.State != ConnectionState.Closed)
connection.Close();
}
[OperationContract]
public int ExecuteNonQuery(CommandType commandType, string commandText, SqlParameter[] nonparams)
{
Open();
command = new SqlCommand(commandText, connection);
command.CommandType = commandType;
command.Parameters.AddRange(nonparams);
int returnValue = command.ExecuteNonQuery();
command.Parameters.Clear();
Close();
return returnValue;
}
[OperationContract]
public SqlDataReader ExecuteReader(CommandType commandType, string commandText, SqlParameter[] readerparams)
{
Open();
command = new SqlCommand(commandText, connection);
command.CommandType = commandType;
if (readerparams != null)
{
command.Parameters.AddRange(readerparams);
}
this.dataReader = command.ExecuteReader();
command.Parameters.Clear();
// Close();
return this.dataReader;
}