Entity Framework Core Lolita

这是Entity Framework Core的一个轻量的扩展,提供批量更新和删除操作的支持。而且这个库出自中国一位MVP之手,虽然内容是英文,也很简单,相信你也能看懂。

This is a light-weight extension which provides bulk update and delete operations for Entity Framework Core.

Getting Started

① Add Pomelo.EntityFrameworkCore.Lolita package into your project.json. There are many different special versions for different EF database provider:

  • Pomelo.EntityFrameworkCore.Lolita.MySql

  • Pomelo.EntityFrameworkCore.Lolita.SqlServer

  • Pomelo.EntityFrameworkCore.Lolita.PostgreSQL

  • Pomelo.EntityFrameworkCore.Lolita.Sqlite

② Configure your DbContext

For ASP.NET Core developers, you can Use lolita extensions when adding the DbContext into services collection:

services.AddDbContext<Models.SampleContext>(x =>
{
    x.UseMySql(
     "server=localhost;database=lolita;uid=root;pwd=yourpwd;");    x.UseMySqlLolita(); });

For .NET Core developers, you can override the OnConfiguring of DbContext to use lolita:

protected override void OnConfiguring(
                          DbContextOptionsBuilder optionsBuilder)
{    optionsBuilder.UseMySql(
        "server=localhost;database=lolita;uid=root;pwd=yourpwd;");    optionsBuilder.UseMySqlLolita();  
 base.OnConfiguring(optionsBuilder); }

③ There are many different extended methods for updating a column or bulk deleting.

Updating:

db.Posts
  .Where(x => x.Time <= DateTime.Now)
  .SetField(x => x.IsPinned).WithValue(false)
  .Update();

You can also use the following methods to update a field:

MethodSQLHint
WithValueSET [x] = @value
PlusSET [x] = [x] + @valueNumeric only
SubtractSET [x] = [x] - @valueNumeric only
MultiplySET [x] = [x] * @valueNumeric only
DivideSET [x] = [x] / @valueNumeric only
ModSET [x] = [x] % @valueNumeric only
PrependSET [x] = @value + [x]String only
AppendSET [x] = [x] + @valueString only
AddMillisecondsSET [x] = DATEADD(ms, @value, [x])DateTime only
AddSecondsSET [x] = DATEADD(ss, @value, [x])DateTime only
AddMinutesSET [x] = DATEADD(mi, @value, [x])DateTime only
AddHoursSET [x] = DATEADD(hh, @value, [x])DateTime only
AddDaysSET [x] = DATEADD(dd, @value, [x])DateTime only
AddMonthsSET [x] = DATEADD(mm, @value, [x])DateTime only
AddYearsSET [x] = DATEADD(yy, @value, [x])DateTime only

Deleting:

db.Users
  .Where(x => db.Posts.Count(y => y.UserId == x.Id) == 0)
  .Where(x => x.Role == UserRole.Member)
  .Delete();
Contribute

One of the easiest ways to contribute is to participate in discussions and discuss issues. You can also contribute by submitting pull requests with code changes.

License

MIT

相关文章:

原文地址:http://www.1234.sh/post/ef-core-lolita


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值