时间:2021-07-01 10:21:17 帮助过:5人阅读
数据库实体及上下文定义
[DbConfigurationType(typeof(MySqlEFConfiguration))] public class Parking : DbContext { public DbSet<Car> Cars { get; set; } public Parking() : base("name=myDb") { } // Constructor to use on a DbConnection that is already opened public Parking(DbConnection existingConnection, bool contextOwnsConnection) : base(existingConnection, contextOwnsConnection) { } protected override void OnModelCreating(DbModelBuilder modelBuilder) { base.OnModelCreating(modelBuilder); modelBuilder.Entity<Car>().MapToStoredProcedures(); } } public class Car { public int CarId { get; set; } [MaxLength(100)] public string Model { get; set; } public int Year { get; set; } [MaxLength(200)] public string Manufacturer { get; set; } }
EF调用示例
public static void EFExecuteExample() { //string connectionString = ConfigurationManager.ConnectionStrings["mydb"].ConnectionString; //using (MySqlConnection connection = new MySqlConnection(connectionString)) //{ // // Create database if not exists // using (Parking contextDB = new Parking(connection, false)) // { // contextDB.Database.CreateIfNotExists(); // } // connection.Open(); // //MySqlTransaction transaction = connection.BeginTransaction(); // try // { // // DbConnection that is already opened // using (Parking context = new Parking(connection, false)) // { // // Interception/SQL logging // context.Database.Log = (string message) => { Console.WriteLine(message); }; // // Passing an existing transaction to the context // // context.Database.UseTransaction(transaction); // // DbSet.AddRange // List<Car> cars = new List<Car>(); // cars.Add(new Car { Manufacturer = "Nissan", Model = "370Z", Year = 2012 }); // cars.Add(new Car { Manufacturer = "Ford", Model = "Mustang", Year = 2013 }); // cars.Add(new Car { Manufacturer = "Chevrolet", Model = "Camaro", Year = 2012 }); // cars.Add(new Car { Manufacturer = "Dodge", Model = "Charger", Year = 2013 }); // context.Cars.AddRange(cars); // context.SaveChanges(); // } // //transaction.Commit(); // } // catch(Exception ex) // { // Console.WriteLine(ex.Message); // //transaction.Rollback(); // throw; // } //} //try //{ // Database.SetInitializer(new DropCreateDatabaseIfModelChanges<Parking>()); var context = new Parking(); // //插入一行值 // context.Cars.Add(new Car { Manufacturer = "Nissan", Model = "370Z", Year = 2012 }); // int result = context.SaveChanges(); //} //catch (Exception ex) //{ // Console.WriteLine(ex.Message); //} Car car = context.Cars.First(item => item.CarId == 1); //根据ID查询 var cars = context.Cars.Where(item => item.Model == "370Z"); // 条件查找
cars = context.Cars.Where(item => item.Year > 2012);
}
MySQL原生访问
static void MySqlDbTest() { MySql.Data.MySqlClient.MySqlConnection conn; string myConnectionString; myConnectionString = ConfigurationManager.ConnectionStrings["myDb"].ConnectionString; try { conn = new MySql.Data.MySqlClient.MySqlConnection(); conn.ConnectionString = myConnectionString; MySqlCommand cmd = conn.CreateCommand(); cmd.CommandType = System.Data.CommandType.Text; cmd.CommandText = "select * from users"; conn.Open(); using (MySqlDataReader reader = cmd.ExecuteReader(CommandBehavior.CloseConnection)) { while (reader.Read()) { Console.WriteLine("id={0},firstname={1},lastname={2}", reader.GetInt32(0), reader.GetString(1), reader.GetString(2)); } } } catch (MySql.Data.MySqlClient.MySqlException ex) { Console.WriteLine(ex.Message); } }
Entity Framework6 访问MySQL
标签: