Example #1
0
        public static void Init()
        {
            Console.WriteLine("");
            Console.WriteLine("#### Queue Start ####");

            SqlSugarClient db = new SqlSugarClient(new ConnectionConfig()
            {
                DbType                = DbType.SqlServer,
                ConnectionString      = Config.ConnectionString,
                InitKeyType           = InitKeyType.Attribute,
                IsAutoCloseConnection = true,
                AopEvents             = new AopEvents
                {
                    OnLogExecuting = (sql, p) =>
                    {
                        Console.WriteLine(sql);
                        Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value)));
                    }
                }
            });

            db.Insertable <Order>(new Order()
            {
                Name = "a"
            }).AddQueue();
            db.Insertable <Order>(new Order()
            {
                Name = "b"
            }).AddQueue();
            db.SaveQueues();


            db.Insertable <Order>(new Order()
            {
                Name = "a"
            }).AddQueue();
            db.Insertable <Order>(new Order()
            {
                Name = "b"
            }).AddQueue();
            db.Insertable <Order>(new Order()
            {
                Name = "c"
            }).AddQueue();
            db.Insertable <Order>(new Order()
            {
                Name = "d"
            }).AddQueue();
            var ar = db.SaveQueuesAsync();

            ar.Wait();

            db.Queryable <Order>().AddQueue();
            db.Queryable <Order>().AddQueue();
            db.AddQueue("select * from [Order] where id=@id", new { id = 10000 });
            db.AddQueue("select id=@id+1", new { id = 10000 });
            var result2 = db.SaveQueues <Order, Order, Order>();

            Console.WriteLine("#### Queue End ####");
        }
Example #2
0
        public static void Init()
        {
            Console.WriteLine("");
            Console.WriteLine("#### Updateable Start ####");

            SqlSugarClient db = new SqlSugarClient(new ConnectionConfig()
            {
                DbType                = DbType.Custom,
                ConnectionString      = Config.ConnectionString,
                InitKeyType           = InitKeyType.Attribute,
                IsAutoCloseConnection = true,
                AopEvents             = new AopEvents
                {
                    OnLogExecuting = (sql, p) =>
                    {
                        Console.WriteLine(sql);
                        Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value)));
                    }
                }
            });



            /*** 1.entity or List ***/

            var updateObj = new Order()
            {
                Id = 1, Name = "order1"
            };
            //var updateObjs = new List<Order> {
            //     new Order() { Id = 11, Name = "order11" },
            //     new Order() { Id = 12, Name = "order12" }
            //};

            //update all columns by primary key
            var result = db.Updateable(updateObj).ExecuteCommand();//update single
            //var result2 = db.Updateable(updateObjs).ExecuteCommand();//update List<Class>

            //Ignore  Name and Price
            var result3 = db.Updateable(updateObj).IgnoreColumns(it => new { it.CreateTime, it.Price }).ExecuteCommand();

            //only update Name and CreateTime
            var result4 = db.Updateable(updateObj).UpdateColumns(it => new { it.Name, it.CreateTime }).ExecuteCommand();

            //If there is no primary key
            var result5 = db.Updateable(updateObj).WhereColumns(it => new { it.Id }).ExecuteCommand();//update single by id
            //var result6 = db.Updateable(updateObjs).WhereColumns(it => new { it.Id }).ExecuteCommand();//update List<Class> by id

            //Re set value
            //var result66 = db.Updateable(new List<Order> { updateObj }).ReSetValue(it => it.Id = 112).IgnoreColumns(it => new { it.CreateTime, it.Price }).ExecuteCommand();



            /*** 2.by expression ***/

            //update  name,createtime
            var result7 = db.Updateable <Order>(it => new Order()
            {
                Name = "a", CreateTime = DateTime.Now
            }).Where(it => it.Id == 11).ExecuteCommand();
            var result71 = db.Updateable <Order>().SetColumns(it => new Order()
            {
                Name = "a", CreateTime = DateTime.Now
            }).Where(it => it.Id == 11).ExecuteCommand();
            //only update name
            var result8  = db.Updateable <Order>(it => it.Name == "Name" + "1").Where(it => it.Id == 1).ExecuteCommand();
            var result81 = db.Updateable <Order>().SetColumns(it => it.Name == "Name" + "1").Where(it => it.Id == 1).ExecuteCommand();
            //



            /*** 3.by Dictionary ***/
            var dt = new Dictionary <string, object>();

            dt.Add("id", 1);
            dt.Add("name", "abc");
            dt.Add("createTime", DateTime.Now);
            var dtList = new List <Dictionary <string, object> >();

            dtList.Add(dt);


            // var t666 = db.Updateable(dtList).AS("[Order]").WhereColumns("id").ExecuteCommand();



            /*** 4.Other instructions ***/

            var caseValue = "1";

            //Do not update NULL columns
            db.Updateable(updateObj).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommand();

            //if 1 update name else if 2 update name,createtime
            db.Updateable(updateObj)
            .UpdateColumnsIF(caseValue == "1", it => new { it.Name })
            .UpdateColumnsIF(caseValue == "2", it => new { it.Name, it.CreateTime })
            .ExecuteCommand();
            //Use Lock
            db.Updateable(updateObj).With(SqlWith.UpdLock).ExecuteCommand();

            //Where Sql
            //db.Updateable(updateObj).Where("id=@x", new { x = "1" }).ExecuteCommand();


            var levelCode = "123213123131321";

            db.Updateable <Order>(a => a.Name == "a")
            .Where(a => SqlFunc.StartsWith(a.Name, levelCode))
            .AddQueue();
            db.SaveQueues();

            //var dataTable = db.Queryable<Order>().Select("id,name,1 as price").Take(2).ToDataTable();
            //db.Fastest<Order>().BulkUpdate("Order", dataTable,new string[] {"id" },new string[] {"name" });
            Console.WriteLine("#### Updateable End ####");
        }