博文 http://www.cnblogs.com/pan11jing/archive/2011/08/19/2051827.html 通过自定义类,再在WCF端转换的方式解决问题,之后出现了一个很小的不便

先给出原博文代码:

首先是添加在WCF端的类:

    [Serializable]
[DataContract]
public class SerSqlParameter
{
public SerSqlParameter(SqlParameter sPara)
{
this.paraName = sPara.ParameterName;
this.paraLen = sPara.Size;
this.paraVal = sPara.Value;
this.sqlDbType = sPara.SqlDbType;
} public SqlParameter ToSqlParameter()
{
SqlParameter para = new SqlParameter(this.paraName, this.sqlDbType, this.paraLen);
para.Value = this.paraVal;
return para;
} [DataMember]
public string ParaName
{
get { return this.paraName; }
set { this.paraName = value; } }
private string paraName = ""; [DataMember]
public int ParaLen
{ get { return this.paraLen; }
set { this.paraLen = value; }
}
private int paraLen = ; [DataMember]
public object ParaVal
{
get { return this.paraVal; }
set { this.paraVal = value; }
}
private object paraVal = null; [DataMember]
public SqlDbType SqlDbType
{
get { return this.sqlDbType; } set { this.sqlDbType = value; }
}
private SqlDbType sqlDbType = SqlDbType.NVarChar;
}

然后在WCF方法中,使用:

public List<QueryResult_Marketing_DealerQuantity> ExecuteQueryMarketing_DealerQuantityBySql(string sql, string key, params SerSqlParameter[] sqlParameters)
{
SqlParameter[] p = new SqlParameter[sqlParameters.Length];
for (int i = ; i < sqlParameters.Length; i++)
{
p[i] = sqlParameters[i].ToSqlParameter();
}
return ExecuteQueryBySql<QueryResult_Marketing_DealerQuantity>(sql, key, p);
}

最后是客户端调用:

List<SerSqlParameter> sqlParameters = new List<SerSqlParameter>();

sqlParameters.Add(new SerSqlParameter(new SqlParameter { ParameterName = "@StartDateTime", SqlDbType = SqlDbType.DateTime, Value = model.StartDateTime }));

var resultList = _wcf.ExecuteQueryMarketing_DealerQuantityBySql(searchSql.ToString(), GlobalVariables.gs_safekey, sqlParameters.ToArray());

问题来了,因为我原来的代码是:

List<SqlParameter> sqlParameters = new List<SqlParameter>();

sqlParameters.Add(new SqlParameter { ParameterName = "@StartDateTime", SqlDbType = SqlDbType.DateTime, Value = model.StartDateTime });

var resultList = _wcf.ExecuteQueryMarketing_DealerQuantityBySql(searchSql.ToString(), GlobalVariables.gs_safekey, sqlParameters.ToArray());

对于每一个添加都需要添加

new SerSqlParameter()

这个工作量,也不是盖的,于是乎想起了这个方法:

/// <summary>
/// 附加追加方法
/// </summary>
/// <param name="sqlParameters"></param>
/// <param name="sqlParameter"></param>
public static void Add(this List<SerSqlParameter> sqlParameters, SqlParameter sqlParameter)
{
SerSqlParameter ser = new SerSqlParameter(sqlParameter);
sqlParameters.Add(ser);
}

这样之后,对于原代码,只需要改个类名就OK了!

WCF SqlParameter序列化问题解决方案的更多相关文章

  1. JavaScriptSerializer中日期序列化问题解决方案

    JavaScriptSerializer中日期序列化问题解决方案 直接进入主题: class Student { public int age { get; set; } public DateTim ...

  2. Hibernate类没有找到序列化器解决方案

    Hibernate类没有找到序列化器解决方案 异常信息类似如下 No serializer found for class org.hibernate.proxy.pojo.javassist.Jav ...

  3. C# 序列化与反序列化之xml对属性或者字段的子类化的子对象进行序列化的解决方案

    C# 序列化与反序列化之xml对属性或者字段的子类化的子对象进行序列化的解决方案 xml序列化涉及到XmlRoot,XmlInclude,XmlElement,XmlAttribute,XmlType ...

  4. C# 序列化与反序列化之DataContract与xml对子类进行序列化的解决方案

    C# 序列化与反序列化之DataContract与xml对子类进行序列化的解决方案 1.DataContract继承对子类进行序列化的解决方案 第一种是在 [DataContract, KnownTy ...

  5. C# 序列化与反序列化之Binary与Soap无法对泛型List<T>进行序列化的解决方案

    C# 序列化与反序列化之Binary与Soap无法对泛型List<T>进行序列化的解决方案 新建Console控制台项目项目,然后添加Team和Person 这2个类,如下: Team和P ...

  6. C#中使用WCF一些常见问题及解决方案

    最近在学习WCF,在这过程当中我遇到了很多的问题,简单说说我遇到的问题已经可能有效的解决方案. 1.在C#中,同一个解决方案下无法引用别的项目,引用之后会有一个警告,查看属性找不到引用的路径,这种情况 ...

  7. Entity Framework在WCF中序列化的问题

    问题描述 如果你在WCF中用Entity Framework来获取数据并返回实体对象,那么对下面的错误一定不陌生. 接收对 http://localhost:5115/ReService.svc 的 ...

  8. WCF发布错误及解决方案

    一:在本机直接运行时出错 使用WCF写了一个小程序测试一下它的功能在运行时报错.“添加服务失败.服务元数据可能无法访问.请确保服务正在运行并且正在公开元数据.” 如下图所示: 查了下资料把它解决了,记 ...

  9. WCF中序列化(XML\JSON\Dt)

    序列化 是将对象转换为容易传输的格式的过程.例如,可以序列化一个对象,然后使用 HTTP 通过 Internet 在客户端和服务器之间传输该对象.反之,反序列化根据流重新构造对象. 序列化描述了持久化 ...

随机推荐

  1. 通配符的匹配很全面, 但无法找到元素 'xxxxxxxx'

    首先,一般配置通配符之前,你都会有如下xml头吧 <beans xmlns="http://www.springframework.org/schema/beans" xml ...

  2. Postgresql 数据库错误修复v0.1

    PS. 查询\nebula_boh\logs\BOHInterfaceLog.log 日志, 一般数据库文件损坏的日志 有 “UncategorizedSQLException” 或 “zero pa ...

  3. Snapshot Types

    Volume managers Some Unix systems have snapshot-capable logical volume managers. These implement cop ...

  4. 一、Java和JavaScript

    JavaScript诞生于1995年,所以他得叫我一声姐姐,(*^__^*) .当时它的主要任务就是表单验证,在还没JavaScript的时候,进行表单验证的时候必须要把数据提交到服务器,才能进行表单 ...

  5. Stateful Future Transformation

    As an async programming pattern, Future has been popular with many of our programmers across a wide ...

  6. JavaScript之DOM对象获取(1)

    我们在操作html中的节点的时候,第一步就需要获取到对应节点(元素),才能有后续的操作.获取节点的方式有很多 1.document.getElementById(‘id值’) 通过id精确的选中某一个 ...

  7. 知乎十万级容器规模的Java分布式镜像仓库实践

    作者:知乎令孤无忌 前言 知乎在 2016 年已经完成了全量业务的容器化,并在自研容器平台上以原生镜像的方式部署和运行,并在后续陆续实施了 CI.Cron.Kafka.HAProxy.HBase.Tw ...

  8. Transaction rolled back because it has been marked as rollback-only

    出现这种错误的原因 1.接口A 调用了接口B 2.接口B报异常了,没有在B里面进行try catch捕获 3.接口A对 接口B进行了try catch捕获 因为接口B报异常 会把当前事物A接口的事物( ...

  9. ES6 块级作用域

    作用域包括:全局作用域,函数作用域,块级作用域. 为什么要用块级作用域: 1.内层变量可能会覆盖外层变量. var name = "kevin"; function call() ...

  10. tensorflow 1.0 学习:池化层(pooling)和全连接层(dense)

    池化层定义在 tensorflow/python/layers/pooling.py. 有最大值池化和均值池化. 1.tf.layers.max_pooling2d max_pooling2d( in ...