菜的像徐坤
排名
6
文章
6
粉丝
16
评论
8
{{item.articleTitle}}
{{item.blogName}} : {{item.content}}
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术

freesql 增删改查

6211人阅读 2022/1/3 22:09 总访问:899931 评论:0 收藏:0 手机
分类: Free sql

前言

freesql 基础(增删改查)

先添加依赖

     private readonly ILogger<HomeController> _logger;
        private readonly IFreeSql _FreeSql = null;

        public HomeController(ILogger<HomeController> logger, IStudent student, IFreeSql FreeSql)
        {
            _logger = logger;
            _FreeSql = FreeSql;
        }

增加

            //增加
            Student student = new Student();
            //查询最大ID 
            student.SId = (Convert.ToInt32(_FreeSql.Select<Student>().Max(a => a.SId)) + 1).ToString();
            student.Sname = "王五";
            student.Sage = DateTime.Now.AddYears(-18);
            student.Ssex = "男";
            var repo = _FreeSql.GetRepository<Student>();
            
            //本次使用的是单个添加,批量添加将 student 替换成List<Student>
            repo.Insert(student);

删除

            //删除
            //出于安全考虑,没有条件不执行删除动作,避免误删除全表数据。删除全表数据:fsql.Delete<T>().Where("1=1").ExecuteAffrows()
            //返回受影响行数
            long delcount =  _FreeSql.Select<Student>().Where(a => a.Sname == "李四").ToDelete().ExecuteAffrows();
            
            //支持删除的4种方式
            //主键集合    new[] { 主键值1, 主键值2 }
            //单个对象
            //对象集合    new[] { Student对象1, Student对象2 }
            //匿名对象    new { id = 1 }
            
            
            //主键集合    new[] { 主键值1, 主键值2 } 
            //主键包含在集合内的数据将会被删除
            //等价于DELETE FROM Student WHERE (SId  = '1' OR SId  = '2')
            var t1 = _FreeSql.Delete<Student>(new[] { "1", "2" }).ToSql();
            
            //单个对象
            //等价于DELETE FROM Student WHERE (SId = '1')
            var t2 = _FreeSql.Delete<Student>(new Student{ SId = "1", Sname = "王五" }).ToSql();
            
             //对象集合
             //等价于DELETE FROM Student WHERE (SId  = '1' OR `SId ` = '2')
             var t3 = _FreeSql.Delete<Student>(new[] { new Student{ SId = "1", Sname = "王五" }, new Student{ SId = "2", Sname = "李四" } }).ToSql();
             
             //匿名对象
             //等价于DELETE FROM Student  WHERE (SId  = '1')
             var t4 = _FreeSql.Delete<Student>(new { SId  = '1'}).ToSql();

修改

            ///修改
            ///方法里传主键值、主键值集合、实体、实体集合、匿名对象、匿名对象集合
            /// _FreeSql.Update<Student>(new[] {"1"})
            /// 或
            ///_FreeSql.Update<Student>(new {"1"})
            ///_FreeSql.Update<Student>("1")
            long count = _FreeSql.Update<Student>("1")
            .Set(a => new Student
            {
                Sname = "李四",
                Ssex = "女"
            })
            .ExecuteAffrows();
            
            
            //set可拼接多个
            long count  = _FreeSql.Update<Student>("1")
           .Set(a => a.Sname == "李四")
           .Set(a => a.Ssex == "女")
           .ExecuteAffrows();

简单查询(查询还有很多种,这里测试了一种最简单的)

            //查询
            List<Student> dt = _FreeSql.Select<Student>().ToList(); //查询
            
            List<Student> dt1 = _FreeSql.Select<Student>().Where(a => a.Ssex == "女").ToList(); //查询

更多信息在freesql官方文档
传送门指南 | FreeSql 官方文档

评价