Entity Framework 学习系列(2) - MySql Database First 开发方式
写在前面
Database First又叫数据库优先的开发方式,是一种比较旧的开发方式,现在已经不再使用这中开发的方式。
当然,对于一些旧项目进行升级,在已经有了数据库的情况下,使用此方式还是十分方便的。
环境
开发环境: win10 家庭版
开发工具:Visual Studio 2019
数据库:MySQL 8.0.17
下载MySQL连接工具
创建Databse First
1.创建控制台
- 选择->新建->项目->windows->控制台应用程序。如图所示:
2.创建数据库
DROP TABLE IF EXISTS `sys_borrow_user`;
CREATE TABLE `sys_borrow_user` (
`user_id` varchar(36) NOT NULL,
`u_id` varchar(255) DEFAULT NULL,
`u_password` varchar(255) DEFAULT NULL,
`gender` varchar(255) DEFAULT NULL,
`user_name` varchar(255) DEFAULT NULL,
`creation_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
`status` varchar(255) DEFAULT NULL,
PRIMARY KEY (`user_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
3.安装 MySQL.Data 和MySQL.Data.Entity
- 选择,工具->NuGet包管理器->管理解决方案的NuGet 程序包
- 搜索MySQL,安装MySql.Data 6.10.9 版本
- 安装MySQL.Data.Entity 6.10.9版本
注意:
在安装 MySql.Data 6.10.9和MySQL.Data.Entity 6.10.9时的版本号要与安装mysql-connector-net-6.10.9.msi的版本号必须要一致。
3.在项目中添加数据实体模型
【1】右击项目,选择添加新项 ,如图所示:
【2】 单击“下一步”按钮,选择"从数据库中生成",如图所示:
【3】新建数据库连接,如图所示:
- 选择MySQL Database。如果没有MySQL Database的选项。可翻看解决mysql的ODBC驱动下载及安装
- 点击下一步,填写配置信息。点击测试测试成功。
【4】在EF中可以直接调用存储过程、视图、函数的,这我们先选择一张表 如图所示:
【5】点击“完成”按钮,最后的展示效果如图:
【6】在代码中添加访问上下文保存到数据库的代码:
- 在APP.config 中找到连接字符串
- 在connectionStrings节点中,添加Password
<add name="mysqldemodbEntities" connectionString="metadata=res://*/MyModel.csdl|res://*/MyModel.ssdl|res://*/MyModel.msl;provider=MySql.Data.MySqlClient;provider connection string="server=localhost;user id=root;Password=root;persistsecurityinfo=True;database=mysqldemodb"" providerName="System.Data.EntityClient" />
- 最后,在Program类中 编写添加的方法
using System;
namespace myEFDatabaseFirst_01
{
class Program
{
static void Main(string[] args)
{
mysqldemodbEntities db = new mysqldemodbEntities();
sys_borrow_user user = new sys_borrow_user() {
user_id = Guid.NewGuid().ToString().Replace("-",""),
u_id="admin",
u_password="admin",
gender="w",
user_name="超级管理员",
creation_time=DateTime.Now,
status="y"
};
db.sys_borrow_user.Add(user);
db.SaveChanges();
}
}
}
EF在SaveChanges 的时候会遍历上下文容器的每一个代理对象,
然后根据代理对象的State属性生成不同的SQL语句。
再一次性的发送到数据库中执行。
执行完成后,我们可以看到数据库中已经插入一条数据。
如图所示:
产生的问题及解决方案
1.问题1
产生问题:
方法“MySql.Data.Entity.EFMySqlCommand.set_DbConnection(System.Data.Common.DbConnection)”
尝试访问方法“MySql.Data.MySqlClient.MySqlConnection.get_Settings()”失败。产生原因:原来是使用的MySql.Data使用的版本过高,默认使用了最新的8.0.17。
解决方案:将MySql.Data的版本改成6.10.9版本。
2.问题2
产生问题
MySqlException: Access denied for user 'root'@'localhost' (using password: NO)。
产生原因:连接字符串没有密码
解决方案:找到连接字符串后,添加Passwork=root;重新生成解决方案。
3.问题3
- 产生问题
出现闪退或者出现如下图所示问题:
产生原因:都是因为项目中引用的MySql.Data.Entity.EF6版本和安装的mysql-connector-net版本不一致。
解决方案:项目中引用的MySql.Data.Entity.EF6版本和安装的mysql-connector-net版本不一致。改成一致即可
Entity Framework 学习系列(2) - MySql Database First 开发方式的更多相关文章
- Entity Framework 学习系列(3) - MySql Code First 开发方式+数据迁移
目录 # 写在前面 一.开发环境 二.创建项目 三.安装程序包 四.创建模型 五.连接字符串 六.编辑程序 七.数据迁移 写在最后 # 写在前面 这几天,一直都在学习Entity Framework ...
- Entity Framework 学习系列(1) - 认识理解Entity Framework
目录 写在前面 什么是Entity Framework EF的优缺点 1.优点 2.缺点 如何理解ORM EF执行的原理 写在前面 在使用.net mvc 开发的时候.为了高效的开发,我们常常会搭配O ...
- Entity Framework 学习系列(4) - EF 增删改
目录 写在前面 一.开发环境 二.创建项目 三.新增 1.单表新增 2.批量新增 3.多表新增 四.编辑 1.先查询,后编辑 2.创建实体,后编辑 五.删除 写在前面 在上一小节中,学习了如何 通过C ...
- Entity Framework 学习系列(5) - EF 相关查询
目录 写在前面 一.使用Stopwatch 查询执行效率 二.简单查询 1.Linq写法: 2.Lambda表达式写法: 三.条件查询 1.Linq 写法 2.lambda 写法 四.聚合函数 1.L ...
- 13本热门书籍免费送!(Python、SpingBoot、Entity Framework、Ionic、MySQL、深度学习、小程序开发等)
七月第一周,网易云社区联合清华大学出版社为大家送出13本数据分析以及移动开发的书籍(Python.SpingBoot.Entity Framework.Ionic.MySQL.深度学习.小程序开发等) ...
- Entity Framework 学习整理(分播客整理)
MSDN: http://msdn.microsoft.com/en-us/data/aa937723 台湾博客: http://www.dotblogs.com.tw/yc421206/ http: ...
- Entity Framework 学习整理
MSDN: http://msdn.microsoft.com/en-us/data/aa937723 台湾博客: http://www.dotblogs.com.tw/yc421206/ http: ...
- Entity Framework入门系列(1)-扯淡开篇
这是我在Cnblogs上的第一个系列,但愿能坚持下去: 惯例索引 Entity Framework入门系列(1)-开篇兼索引: Entity Framework入门系列(2)-初试Code First ...
- Entity Framework 学习
Entity Framework 学习初级篇1--EF基本概况 Entity Framework 学习初级篇2--ObjectContext.ObjectQuery.ObjectStateEntry. ...
随机推荐
- MySQL数据库(六)-- SQL注入攻击、视图、事物、存储过程、流程控制
一.SQL注入攻击 1.什么是SQL注入攻击 一些了解sql语法的用户,可以输入一些关键字 或合法sql,来导致原始的sql逻辑发生变化,从而跳过登录验证 或者 删除数据库 import pymysq ...
- 基于KVM的虚拟机创建
KVM基本介绍: KVM是Kernel-based Virtual Machine的简称,是一个开源的系统虚拟化模块,自Linux 2.6.20之后集成在Linux的各个主要发行版本中,KVM目前 ...
- 大数据技术原理与应用【第五讲】NoSQL数据库:5.1 NoSQL概论&5.2 NoSQL与关系数据库的比较
5.1 NoSQL概论 最初:反SQL 概念演变,现在:Not only SQL 特点: 1.灵活的可扩展性 所以支持海量数据存储 2.灵活的数据模型 例如:HBase 3.和云计算的紧密结合 (一) ...
- Leetcode——1. 两数之和
难度: 简单 题目 Given an array of integers, return indices of the two numbers such that they add up to a s ...
- P4137 Rmq Problem / mex(主席树)
传送门 思路: 直接上主席树,对于每个询问\((l,r)\),我们在第\(r\)个版本的主席树中查询最晚出现的小于\(l\)最小的数就行了. 因为答案可能为\(a_i+1\),所以我们在离散化的时候考 ...
- 安装Visual Studio 时窗口闪过就退出
双击安装文件,窗口闪了下就退出了. 解决方法:控制面板 ———程序——程序和功能——打开或关闭Windows功能——关闭NET相关框架. 然后再次安装即可. 参考文献: VS安装程序一闪而过
- Wpf DataGrid动态添加列,行数据(一)
由于最近有这方面的需求,而且刚接触wpf不久,在网上找了很多方法,都不是使用MVVM模式的,因为DataGrid的列不能绑定 这就难受了,我想了个折中的方法,这个是使用了MVVMLight的消息机制, ...
- Python 文件读写操作实例详解
Python提供了必要的函数和方法进行默认情况下的文件基本操作.你可以用file对象做大部分的文件操作 一.python中对文件.文件夹操作时经常用到的os模块和shutil模块常用方法.1.得到当前 ...
- Python 模块A
模块的四种形式 自定义模块,例如自己定义的common.py就叫common模块 内置模块:python解释器自带的,不需要安装 第三方模块:需要自己安装,13万个库,无所不能,写库(弄得更简单) 包 ...
- Python基础B(数据类型----交互)
数据类型 数字类型 一.整型(int) age = 18 % age=int(18) print(id(age)) print(type(age)) print(age) 4530100848 < ...