Linq To Sql进阶系列(六)用object的动态查询与保存log篇
[1] Linq To Sql进阶系列(六)用object的动态查询与保存log篇
[2] Linq To Sql进阶系列(六)用object的动态查询与保存log篇
[3] Linq To Sql进阶系列(六)用object的动态查询与保存log篇
[2] Linq To Sql进阶系列(六)用object的动态查询与保存log篇
[3] Linq To Sql进阶系列(六)用object的动态查询与保存log篇
系列文章导航:
Linq To Sql进阶系列(四)User Define Function篇
Linq To Sql进阶系列(五)Store Procedure篇
Linq To Sql进阶系列(六)用object的动态查询与保存log篇
Linq To Sql进阶系列(七)动态查询续及CLR与SQL在某些细节上的差别
4,测试用例及反思
我们用下面的例子来测试下这个函数
data:image/s3,"s3://crabby-images/e53f4/e53f48feb5606f920bb0d845540c1729c7546489" alt=""
data:image/s3,"s3://crabby-images/e53f4/e53f48feb5606f920bb0d845540c1729c7546489" alt=""
data:image/s3,"s3://crabby-images/e53f4/e53f48feb5606f920bb0d845540c1729c7546489" alt=""
data:image/s3,"s3://crabby-images/e53f4/e53f48feb5606f920bb0d845540c1729c7546489" alt=""
data:image/s3,"s3://crabby-images/e53f4/e53f48feb5606f920bb0d845540c1729c7546489" alt=""
其生成的sql语句为:
data:image/s3,"s3://crabby-images/e53f4/e53f48feb5606f920bb0d845540c1729c7546489" alt=""
[t0].[Address], [t0].[City], [t0].[Region], [t0].[PostalCode], [t0].[Country], [t0].[Phone],
[t0].[Fax]
data:image/s3,"s3://crabby-images/e53f4/e53f48feb5606f920bb0d845540c1729c7546489" alt=""
data:image/s3,"s3://crabby-images/e53f4/e53f48feb5606f920bb0d845540c1729c7546489" alt=""
data:image/s3,"s3://crabby-images/e53f4/e53f48feb5606f920bb0d845540c1729c7546489" alt=""
data:image/s3,"s3://crabby-images/e53f4/e53f48feb5606f920bb0d845540c1729c7546489" alt=""
我们可以看到,其sql语句中,只有city和phone两个条件。并且他们之间是and的关系。我们最开始的设想实现了,但是,它是完美的吗?如果是or条件该怎么办呢?更多的时候,我们是在用模糊查询,那又该怎么办呢?这个问题,就留于下篇。
最后,介绍一种写log的方法。stream流使用static为避免多个datacontext的同时在使用log.txt文件。
data:image/s3,"s3://crabby-images/e53f4/e53f48feb5606f920bb0d845540c1729c7546489" alt=""
data:image/s3,"s3://crabby-images/7eaf8/7eaf8d46136bcc184d2a041a432245b545c54ce6" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
GetCurrentDirectory(), "log.txt"),true);
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/8cb45/8cb45160f313bc11a0fa665bba5d3d38f8eea9a5" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/b9e1a/b9e1a62fa7d63b837c4c169e3cdf83f2b70b54aa" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/8cb45/8cb45160f313bc11a0fa665bba5d3d38f8eea9a5" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/8cb45/8cb45160f313bc11a0fa665bba5d3d38f8eea9a5" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/8cb45/8cb45160f313bc11a0fa665bba5d3d38f8eea9a5" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
true);
data:image/s3,"s3://crabby-images/b9e1a/b9e1a62fa7d63b837c4c169e3cdf83f2b70b54aa" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/b9e1a/b9e1a62fa7d63b837c4c169e3cdf83f2b70b54aa" alt=""
data:image/s3,"s3://crabby-images/b9e1a/b9e1a62fa7d63b837c4c169e3cdf83f2b70b54aa" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/8cb45/8cb45160f313bc11a0fa665bba5d3d38f8eea9a5" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/b9e1a/b9e1a62fa7d63b837c4c169e3cdf83f2b70b54aa" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/8cb45/8cb45160f313bc11a0fa665bba5d3d38f8eea9a5" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/4692b/4692b9ac590970b6d9e142806da27759d412162f" alt=""
data:image/s3,"s3://crabby-images/b9e1a/b9e1a62fa7d63b837c4c169e3cdf83f2b70b54aa" alt=""
data:image/s3,"s3://crabby-images/98b7e/98b7ef682548793c876ffab925a56bbaebf0cf21" alt=""
在dispose函数里,把输出流flush。使用时,如下
using(northwind db = new norhwind(true))
{
//do something......
}
好,就先讲到这里。