复杂点的使用2


InsertAll, UpdateAll and DeleteAll 的参数要是IEnumerables


Each关键字 返回 IEnumerable 并且是延迟加载的


全局设置 当字符串为null时候,设置一个默认值

OrmLiteConfig.OnDbNullFilter = fieldDef = >

fieldDef.FieldType == typeof(string) ? "NULL" : null;

执行sql的时候过滤

public class MockStoredProcExecFilter : OrmLiteExecFilter

{

public override T Exec(IDbConnection dbConn, Func<IDbCommand, T> filter)

{

try

{

return base.Exec(dbConn, filter);

}

catch (Exception ex)

{

if (dbConn.GetLastSql() == "exec sp_name @firstName, @age")

return (T)(object)new Person { FirstName = "Mocked" };

throw;

}

}

}

OrmLiteConfig.ExecFilter = new MockStoredProcExecFilter();

using (var db = OpenDbConnection())

{

var person = db.SqlScalar("exec sp_name @firstName, @age",

new { firstName = "aName", age = 1 });

person.FirstName.Print(); //Mocked

}


CaptureSqlFilter

跟踪 可以在调试窗口看到了

using (var captured = new CaptureSqlFilter())

using (var db = OpenDbConnection())

{

db.Where(new { Age = 27 });

captured.SqlStatements[0].PrintDump();

}


同上 重复执行

public class ReplayOrmLiteExecFilter : OrmLiteExecFilter

{

public int ReplayTimes { get; set; }

public override T Exec<T>(IDbConnection dbConn, Func<IDbCommand, T> filter)
{
var holdProvider = OrmLiteConfig.DialectProvider;
var dbCmd = CreateCommand(dbConn);
try
{
var ret = default(T);
for (var i = 0; i < ReplayTimes; i++)
{
ret = filter(dbCmd);
}
return ret;
}
finally
{
DisposeCommand(dbCmd);
OrmLiteConfig.DialectProvider = holdProvider;
}
}

}

OrmLiteConfig.ExecFilter = new ReplayOrmLiteExecFilter { ReplayTimes = 3 };

using (var db = OpenDbConnection())

{

db.DropAndCreateTable();

db.Insert(new PocoTable { Name = "Multiplicity" });

var rowsInserted = db.Count<PocoTable>(q => q.Name == "Multiplicity"); //3

}


单元测试 模拟返回的数据

下面返回的数据都是假的,山寨的

using (new OrmLiteResultsFilter {

PrintSql = true,

SingleResult = new Person {

Id = 1, FirstName = "Mocked", LastName = "Person", Age = 100

},

})

{

db.Single(x => x.Age == 42).FirstName // Mocked

db.Single(db.From().Where(x => x.Age == 42)).FirstName // Mocked

db.Single(new { Age = 42 }).FirstName // Mocked

db.Single("Age = @age", new { age = 42 }).FirstName // Mocked

}


一看就懂 字符串过滤 还有这玩意居然

OrmLiteConfig.StringFilter = s => s.TrimEnd();

db.Insert(new Poco { Name = "Value with trailing " });

db.Select().First().Name // "Value with trailing"


可插入 可拔出的 复杂类型序列化

据说ServiceStack's的json序列化效率最高

//ServiceStack's JSON and JSV Format

SqliteDialect.Provider.StringSerializer = new JsvStringSerializer();

PostgreSqlDialect.Provider.StringSerializer = new JsonStringSerializer();

//.NET's XML and JSON DataContract serializers

SqlServerDialect.Provider.StringSerializer = new DataContractSerializer();

MySqlDialect.Provider.StringSerializer = new JsonDataContractSerializer();

//.NET XmlSerializer

OracleDialect.Provider.StringSerializer = new XmlSerializableSerializer();

code first的时候会用到吧

public class PocoTable

{

public int Id { get; set; }

[CustomField("CHAR(20)")]
public string CharColumn { get; set; } [CustomField("DECIMAL(18,4)")]
public decimal? DecimalColumn { get; set; }

}

db.CreateTable();

结果:CREATE TABLE "PocoTable"

(

"Id" INTEGER PRIMARY KEY,

"CharColumn" CHAR(20) NULL,

"DecimalColumn" DECIMAL(18,4) NULL

);


可以这样调用存储过程的

List results = db.SqlList("EXEC GetAnalyticsForWeek 1");

List results = db.SqlList(

"EXEC GetAnalyticsForWeek @weekNo", new { weekNo = 1 });

List results = db.SqlList("EXEC GetTotalsForWeek 1");

List results = db.SqlList(

"EXEC GetTotalsForWeek @weekNo", new { weekNo = 1 });

int result = db.SqlScalar("SELECT 10");

搞个带参数的存储过程

string spSql = @"DROP PROCEDURE IF EXISTS spSearchLetters;

CREATE PROCEDURE spSearchLetters (IN pLetter varchar(10), OUT pTotal int)

BEGIN

SELECT COUNT(*) FROM LetterFrequency WHERE Letter = pLetter INTO pTotal;

SELECT * FROM LetterFrequency WHERE Letter = pLetter;

END";

db.ExecuteSql(spSql);

using (var cmd = db.SqlProc("spSearchLetters", new { pLetter = "C" }))

{

var pTotal = cmd.AddParam("pTotal", direction: ParameterDirection.Output);

var results = cmd.ConvertToList<LetterFrequency>();
var total = pTotal.Value;

}

换个姿势加参数

IDbDataParameter pTotal = null;

var results = db.SqlList("spSearchLetters", cmd => {

cmd.CommandType = CommandType.StoredProcedure;

cmd.AddParam("pLetter", "C");

pTotal = cmd.AddParam("pTotal", direction: ParameterDirection.Output);

});

var total = pTotal.Value;


设置字段的默认值 g点在这里OrmLiteVariables

public class Poco

{

[Default(OrmLiteVariables.SystemUtc)] //= {SYSTEM_UTC}

public DateTime CreatedTimeUtc { get; set; }

}

ServiceStack.OrmLite 笔记8 -还是有用的姿势的更多相关文章

  1. ServiceStack.OrmLite 笔记2 -增

    ServiceStack.OrmLite 笔记2 这篇主要介绍 增加 db.Insert(new Employee { Id = 1, Name = "Employee 1" }) ...

  2. ServiceStack.OrmLite 笔记

    ServiceStack.OrmLite 笔记1 ServiceStack.OrmLite 这个东东就是个orm框架,可以实现类似ef的效果.具体的就不这里班门弄斧了. 支持 SqlServerDia ...

  3. ServiceStack.OrmLite 笔记9 -code first 必须的代码优先

    复杂点的使用3 code first的使用,支持复杂类型 public enum PhoneType { Home, Work, Mobile, } public enum AddressType { ...

  4. ServiceStack.OrmLite 笔记4 删

    删除 db.DeleteAll(); //各种姿势 db.Delete(p => p.Age == 27);// db.Delete(q => q.Where(p => p.Age ...

  5. ServiceStack.OrmLite 笔记10-group having 分页orderby等

    group having 分页等 var ev = OrmLiteConfig.DialectProvider.SqlExpression(); group的使用 同sql一样,注意group分组的字 ...

  6. ServiceStack.OrmLite 笔记5 改

    修改 db.Update(new Person { Id = 1, FirstName = "Jimi", LastName = "Hendrix", Age ...

  7. ServiceStack.OrmLite 学习笔记7-复杂点的使用1

    复杂点的使用1 先看看这2个类 class Customer { public int Id { get; set; } ... } class CustomerAddress { public in ...

  8. ServiceStack.OrmLite

    ServiceStack.OrmLite 谈谈我的入门级实体框架Loogn.OrmLite   每次看到有新的ORM的时候,我总会留意一下,因为自己也写过一个这样的框架,人总是有比较之心的.我可能会d ...

  9. ServiceStack.OrmLite中的一些"陷阱"(2)

    注:此系列不是说ServiceStack.OrmLite的多个陷阱,这仅仅个人认为是某一个陷阱(毕竟我踩坑了)而引发的思考. 前文说到了项目需要使用两种不同的数据库语言,虽说前文问题已基本解决了,但是 ...

随机推荐

  1. Android开机自启动程序

    背景知识:当Android启动时,会发出一个系统广播,内容为ACTION_BOOT_COMPLETED,它的字符串常量表示为 android.intent.action.BOOT_COMPLETED. ...

  2. 搭建无限制权限的简单git服务器使用git-daemon脚本

    如果想要用ubantu架设无限制权限(即不适用gitosis)的简单git服务器,实现git库下载clone,push等简单的基本功能, 可以直接使用git-daemon脚本(非常不安全,建议项目代码 ...

  3. android 应用架构随笔六(Loading加载页面)

    import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import com.heima ...

  4. 在Dll中使用 TFDQuery 的 LoadFromStream 方法注意问题

    今天又遇到一怪事,  FDQuery 在服务器 savestream 传回了客户端. 客户端接收后 loadfromstream 接收都正常.  但当我把客户端封装成 dll 时,loadfromst ...

  5. Nginx+Keepalived实现 转载

    一.Keepalived简介 keepalived是一个类似于layer3, 4 & 5交换机制的软件,也就是我们平时说的第3层.第4层和第5层交换.Keepalived的作用是检测web服务 ...

  6. JavaEE基础(二十七)/反射、JDK新特性

    1.反射(类的加载概述和加载时机) A:类的加载概述 当程序要使用某个类时,如果该类还未被加载到内存中,则系统会通过加载,连接,初始化三步来实现对这个类进行初始化. 加载  就是指将class文件读入 ...

  7. HDU 2665 && POJ 2104(主席树)

    http://poj.org/problem?id=2104 对权值进行建树(这个时候树的叶子是数组b的有序数列),然后二分查找原数列中每个数在有序数列中的位置(即第几小),对每一个前缀[1,i]建一 ...

  8. Android 5.1 - 状态栏充电标志问题

    Android 5.1 Ubuntu14.04  SourceInsigh 电量已满,插着USB头,观察Settings - Battery,电量为100%,状态为full,但仍有充电图标rust 之 ...

  9. rtc关机闹钟6 AlarmManagerService研究

    这个是 private void setLocked(int type, long when) { if (mNativeData != 0) {            // The kernel n ...

  10. Android之Handler用法总结(1)

    方法一:(java习惯,在android平台开发时这样是不行的,因为它违背了单线程模型) 刚刚开始接触android线程编程的时候,习惯好像java一样,试图用下面的代码解决问题 new Thread ...