using System; using System.Data; using System.Threading.Tasks; using Dapper; using DotNetCore.CAP; using Microsoft.AspNetCore.Mvc; using MySql.Data.MySqlClient; namespace Sample.RabbitMQ.MySql.Controllers { [Route("api/[controller]")] public class ValuesController : Controller { private readonly ICapPublisher _capBus; public ValuesController(ICapPublisher capPublisher) { _capBus = capPublisher; } [Route("~/without/transaction")] public async Task WithoutTransaction() { await _capBus.PublishAsync("sample.rabbitmq.mysql", DateTime.Now); return Ok(); } [Route("~/adonet/transaction")] public IActionResult AdonetWithTransaction() { using (var connection = new MySqlConnection(AppDbContext.ConnectionString)) { using (var transaction = connection.BeginTransaction(_capBus, autoCommit: false)) { //your business code connection.Execute("insert into test(name) values('test')", transaction: (IDbTransaction)transaction.DbTransaction); for (int i = 0; i < 5; i++) { _capBus.Publish("sample.rabbitmq.mysql", DateTime.Now); } transaction.Commit(); } } return Ok(); } [Route("~/ef/transaction")] public IActionResult EntityFrameworkWithTransaction([FromServices]AppDbContext dbContext) { using (var trans = dbContext.Database.BeginTransaction(_capBus, autoCommit: false)) { dbContext.Persons.Add(new Person() { Name = "ef.transaction" }); for (int i = 0; i < 5; i++) { _capBus.Publish("sample.rabbitmq.mysql", DateTime.Now); } dbContext.SaveChanges(); trans.Commit(); } return Ok(); } [NonAction] [CapSubscribe("#.rabbitmq.mysql")] public void Subscriber(DateTime time) { Console.WriteLine($@"{DateTime.Now}, Subscriber invoked, Sent time:{time}"); } } }