You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

46 lines
2.0 KiB

4 years ago
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text;
  4. namespace Apewer.Source
  5. {
  6. /// <summary>数据库引擎支持 ORM 访问。</summary>
  7. public interface IOrm : IDatabase
  8. {
  9. /// <summary>初始化指定类型,以创建表或增加字段。</summary>
  10. /// <param name="model">要初始化的类型。</param>
  11. /// <returns>错误信息。当成功时候返回空字符串。</returns>
  12. public string Initialize(Type model);
  13. /// <summary>插入记录。</summary>
  14. /// <param name="record">要插入的记录实体。</param>
  15. /// <returns>错误信息。当成功时候返回空字符串。</returns>
  16. public string Insert(Record record);
  17. /// <summary>更新记录。</summary>
  18. /// <param name="record">要插入的记录实体。</param>
  19. /// <returns>错误信息。当成功时候返回空字符串。</returns>
  20. public string Update(Record record);
  21. /// <summary>获取指定类型的主键,按 Flag 属性筛选。</summary>
  22. /// <param name="model">要查询的类型。</param>
  23. /// <param name="flag">要求目标记录具有的 Flag 属性,当指定 0 时忽略此要求。</param>
  24. public Result<List<string>> Keys(Type model, long flag = 0);
  25. /// <summary>获取具有指定 Key 的记录,并要求记录具有指定的 Flag 属性。</summary>
  26. /// <param name="key">目标记录的主键。</param>
  27. /// <param name="flag">要求目标记录具有的 Flag 属性,当指定 0 时忽略此要求。</param>
  28. public Result<T> Get<T>(string key, long flag = 0) where T : Record;
  29. /// <summary>使用指定语句查询,获取查询结果。</summary>
  30. public Result<List<T>> Query<T>(string sql) where T : Record;
  31. /// <summary>查询所有记录。</summary>
  32. /// <param name="flag">要求目标记录具有的 Flag 属性,当指定 0 时忽略此要求。</param>
  33. public Result<List<T>> Query<T>(long flag = 0) where T : Record;
  34. }
  35. }