.netcore下使用Chloe.ORM框架

一、引言

Chloe.ORM是一款轻量、高效的类EF数据库访问框架(ORM)。查询接口借鉴 Linq(不支持 Linq),之前使用过EF很容易上手。Chloe目前支持四种主流数据库:SqlServer、MySQL、Oracle、Sqlite。

二、项目搭建

1.搭建项目架构

Test.Web:.netcore webapi项目

Test.Model:.netcore类库项目,存放api接口输入输出实体类、以及数据库表映射的实体类型

Test.DB:.netcore类库项目,实现对数据库访问的封装

在Test.Web添加对Test.DB、Test.Model项目的引用

2.Nuget安装Chloe

(1)在Test.DB项目下使用nuget安装Chloe和Chloe.SqlServer

(2)在Test.Model子项目下使用Nuget安装Chloe

3.在Test.DB子项目下新建基础操作类

using Chloe;
using System;
using System.Collections.Generic;
using System.Linq.Expressions;

namespace Test.DB
{
    public class DB
    {
        private IDbContext NewDB()
        {
            var sqlserver_conn_str = "database=Archives;server=.;User=test;password=123;";
            return new Chloe.SqlServer.MsSqlContext(sqlserver_conn_str);
        }
        #region 基础操作
        /// <summary>
        /// 新增,如果一个实体存在自增列,会自动将自增列设置到相应的属性上
        /// </summary>
        /// <param name="entity">实体</param>
        public T Insert<T>(T entity) where T : class, new()
        {
            using (var db = NewDB())
            {
                return db.Insert(entity);
            }
        }
        /// <summary>
        /// 修改
        /// </summary>
        /// <param name="entity">实体</param>
        public int Update<T>(T entity) where T : class, new()
        {
            using (var db = NewDB())
            {
                return db.Update(entity);
            }
        }
        /// <summary>
        /// 删除
        /// </summary>
        /// <param name="expWhere"></param>
        public int Delete<T>(Expression<Func<T, bool>> expWhere) where T : class, new()
        {
            using (var db = NewDB())
            {
                return db.Delete<T>(expWhere);
            }
        }
        /// <summary>
        /// 获取一个实体
        /// </summary>
        /// <param name="expWhere">查询条件</param>
        /// <returns></returns>
        public T Find<T>(Expression<Func<T, bool>> expWhere) where T : class, new()
        {
            using (var db = NewDB())
            {
                IQuery<T> q = db.Query<T>();
                var entity = q.Where(expWhere).FirstOrDefault();
                return entity;
            }
        }
        /// <summary>
        /// 单表查询
        /// </summary>
        /// <param name="expWhere">查询条件,可空</param>
        /// <param name="expOrder">排序字段,可空</param>
        /// <param name="isAsc">是否升序,expOrder不为空时有效</param>
        /// <returns></returns>
        public IEnumerable<T> FindList<T>(Expression<Func<T, bool>> expWhere = null, Expression<Func<T, object>> expOrder = null, bool isAsc = false) where T : class, new()
        {
            using (var db = NewDB())
            {
                IQuery<T> q = db.Query<T>();
                if (expWhere != null)
                {
                    q = q.Where(expWhere);
                }
                if (expOrder != null)
                {
                    if (isAsc)
                    {
                        q = q.OrderBy(expOrder);
                    }
                    else
                    {
                        q = q.OrderByDesc(expOrder);
                    }
                }
                var list = q.ToList();
                return list;
            }
        }
        /// <summary>
        /// 根据sql语句查询
        /// </summary>
        /// <param name="strSql">sql语句</param>
        /// <param name="parameters">参数</param>
        /// <returns></returns>
        public IEnumerable<T> DtoQuery<T>(string strSql, params DbParam[] parameters) where T : class, new()
        {
            using (IDbContext db = NewDB())
            {
                return db.SqlQuery<T>(strSql, parameters);
            }
        }
        #endregion
    }
}

4.在Test.Model下添加数据库表UserConfig映射的实体类

using System;
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;
using Chloe.Annotations;
using Chloe.Entity;

namespace Test.Model
{
    /// <summary>
    /// UserConfig(用户配置表)实体类
    ///</summary>
    [Table("UserConfig")]
    public class UserConfig
    {
        #region 获取/设置 字段值
        /// <summary>
        /// 唯一标识
        /// </summary>
        /// <returns></returns>
        [Column(IsPrimaryKey = true)]
        [DisplayName("唯一标识")]
        public string Id { get; set; }
        /// <summary>
        /// 用户ID
        /// </summary>
        /// <returns></returns>
        [DisplayName("用户ID")]
        public string UserId { get; set; }
        /// <summary>
        /// 配置key
        /// </summary>
        /// <returns></returns>
        [DisplayName("配置key")]
        public string ConfigKey { get; set; }
        /// <summary>
        /// 配置value
        /// </summary>
        /// <returns></returns>
        [DisplayName("配置value")]
        public string ConfigValue { get; set; }
        /// <summary>
        /// 项目编码
        /// </summary>
        /// <returns></returns>
        [DisplayName("项目编码")]
        public string ProjectCode { get; set; }
        /// <summary>
        /// 备注
        /// </summary>
        /// <returns></returns>
        [DisplayName("备注")]
        public string Memo { get; set; }
        /// <summary>
        /// 创建时间
        /// </summary>
        /// <returns></returns>
        [DisplayName("创建时间")]
        public DateTime? CreateTime { get; set; }
        /// <summary>
        /// 修改时间
        /// </summary>
        /// <returns></returns>
        [DisplayName("修改时间")]
        public DateTime? UpdateTime { get; set; }
        #endregion
    }
}

5.在Test.Web中添加控制器调用

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using Test.Model;
using Test.Model.InputParam;
using Test.Model.OutputParam;

namespace Test.Web.Controllers
{
    /// <summary>
    /// Home控制器
    /// </summary>
    [Route("api/[controller]/[action]")]
    [ApiController]
    public class HomeController : ControllerBase
    {
        /// <summary>
        /// 查询用户
        /// </summary>
        /// <param name="input"></param>
        /// <returns></returns>
        [HttpGet]
        public IEnumerable<UserConfig> UserSearch()
        {
            var list = new Test.DB.DB().FindList<UserConfig>();
            return list;
        }

    }
}

因为Chloe没有将数据库表自动生成为Model实体类的工具,自行编写一个代码生成器是个比较好的选择。

值的一提的是,==和Equals是有区别的,这个之前在EF中就有发现:

/* 使用此方法与双等号(==)的区别是:a => Sql.Equals(a.Name, a.XName) 会被翻译成 a.Name == a.XName,
       而 a => a.Name == a.XName 则会被翻译成 a.Name == a.XName or (a.Name is null and a.XName is null) */
    public static bool Equals<T>(T value1, T value2);

Chole官方网站文档参考:https://github.com/shuxinqin/Chloe

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
.NET Core IoT框架是一个为物联网(IoT)应用程序开发设计的开源框架。它提供了一个跨平台的、轻量级的运行时环境,可用于构建可靠、高效的IoT解决方案。 首先,.NET Core IoT框架支持多种硬件平台,包括嵌入式设备和单板计算机,例如树莓派和Arduino等。这使得开发人员可以在不同的环境中轻松部署和运行他们的应用程序,而无需担心硬件兼容性问题。 其次,框架提供了丰富的API和工具,使开发人员能够方便地访问和控制物联网设备的各种功能和传感器。例如,开发人员可以利用框架提供的API读取温度、湿度和光照等传感器数据,或者控制设备的LED灯、电机和继电器等输出设备。 此外,.NET Core IoT框架提供了强大的网络连接功能,使开发人员能够轻松地将物联网设备与云平台和其他设备进行通信。开发人员可以使用框架的网络库来实现远程传感器数据传输、设备控制和远程监控等功能。 还值得一提的是,.NET Core IoT框架具有高度的可扩展性和灵活性。开发人员可以根据自己的需求选择所需的模块和组件,以构建自定义的IoT解决方案。框架还支持使用不同的编程语言,例如C#和F#,以满足不同开发人员的喜好和技能。 总而言之,.NET Core IoT框架是一个功能强大且易于使用的开源框架,可帮助开发人员快速构建高效可靠的物联网应用程序。它的跨平台支持、丰富的API和工具,以及强大的网络连接功能使其成为物联网开发的理想选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数据的流

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值