如何用VS EF连接 Mysql,以及执行SQL语句 和存储过程?
VS2013, MySQL5.7.18 , MySQL5.7.14
执行SQL语句:
ztp_user z = new ztp_user();
object[] obj = new object[] { z };
MySqlParameter[] p = new MySqlParameter[]{
new MySqlParameter("@username","admin1")
};
var result = db.Database.SqlQuery<ztp_user>("SELECT * from ztp_user where username=@username LIMIT 10", p).ToList();
执行存储过程:
DateTime beginDateTime = Convert.ToDateTime("2017-10-21");
DateTime endDateTime = Convert.ToDateTime("2017-10-22");
int beginTimeStamp = 1508515200;
int endTimeStamp = 1508601600;
var result = db.sp_BI(beginDateTime, endDateTime, beginTimeStamp, endTimeStamp).ToList();
http://www.360doc.com/content/14/0709/00/5054188_393081769.shtml
使用过程中遇到的坑:
线上的数据库需要新写一个存储过程,不能在线上直接操作,需要从线上导出一个数据库,最新的数据
坑一:导出的sql文件,需要导入的时候报错,总提示语法错误
原因是线上的MySQL版本和本地的版本不一致
解决方案:
.MySQL导入数据从5.7.18 高版本导入到低版本数据5.7.14时候提示语法错误:
需要将双引号替换成单引号
CREATE TABLE "ztp_admin_nav" (
双引号替换成单引号
坑二:安装了VS后还不能直接连接使用MySQL,需要安装插件
解决方案:
1、mysql-for-visualstudio:Mysql的Visual Studio插件,推荐1.2.3版本
2、mysql-connector-net:.net连接Mysql的程序,推荐6.8.3,版本。如果安装高版本可能导致一系列问题。详见:http://blog.csdn.net/niewq/article/details/41877301。
http://www.cnblogs.com/wangwust/p/6638666.html
坑三:插件也安装好了,使用 EF,DB first的时候,生成Model的时候又报错了
StrongTypingException: The value for column 'IsPrimaryKey' in table 'TableDetails' is DBNull.'.
解决方案:
1.重启mysql 服务
2.set global optimizer_switch='derived_merge=OFF';
EF连接mysql的时候:
1.重启mysql服务
use <<database name>>
2. set global optimizer_switch='derived_merge=OFF';
3.添加EF ADO.NET ENTITY
Unexpected exception occurred when generating the model. See output window for more details. Exception message : 'StrongTypingException: The value for column 'IsPrimaryKey' in table 'TableDetails' is DBNull.'.
https://stackoverflow.com/questions/31961646/ef6-mysql-strongtypingexception-when-column-is-not-pk
坑四:发现在MySQL中执行这个命令的时候又报错了,无法设置 Global derived-merge
出现 1055 sql group by order by 错误1055 错误
解决方案:
修改 sql model 避免 group by 错误 Group by 出错:
推荐新的修改方法:
按需修改
select @@global.sql_mode;
set @@global.sql_mode ='REAL_AS_FLOAT,PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE';
重启mysql
老的修改方法:
select @@global.sql_mode;
set @@global.sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
坑五:正常情况,修改MySQL 的sql model后,group by的问题就可以解决了
但是这次还不行,执行 set global optimizer_switch='derived_merge=OFF'; 依然报1055错
Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated column 'inform:
解决方案:
1.修改my.cnf 最后一行添加 sql_mode='NO_ENGINE_SUBSTITUTION'
http://www.cnblogs.com/gaojupeng/p/5740011.html
windows上面是my.ini
linux上面是 my.cnf
2.重启mysql
坑六:EF终于可以添加上model了,但是写代码的时候报错,找不到命名空间
解决方案:
C#连接MySQL缺少引用命名空间:
引入MySQL.Data.dll
http://blog.csdn.net/zzzzzzzert/article/details/7925497
坑七:
代码终于写完,调试也可以了,写完发布到服务器上面,又报错了,本地可以,服务器不行,这个就更坑了,开启web config 报错提示 customer error model =“OFF”,看到了报错信息
报错:Facet 'Precision' must not be specified for type 'datetime'.
是因为存储过程中使用了 timestamp 类型的参数
本地5.7.14 可以EF可以连接存储过程成功,发布后MySQL使用5.7.18版本不兼容数据类型
解决方案:
存储过程的数据类型,从timestamp 改成了 varchar(50),传参数‘2017-10-25’
再次发布使用EF可以成功连接MySQL
终于线上可以用了,调用MySQL存储过程,调用sql语句
如何用VS EF连接 Mysql,以及执行SQL语句 和存储过程?的更多相关文章
- JDBC连接MYSQL,批量执行SQL语句或在执行一个SQL语句之前执行一个SQL语句
conn = MysqlJdbcUtils.getConnection(); Statement ps=conn.createStatement(); ps.addBatch("trunca ...
- Python连接MySQL数据库执行sql语句时的参数问题
由于工作需要,今天写了一个Python小脚本,其中需要连接MySQL数据库,在执行sql命令时需要传递参数,结果出问题了.在网上查了一下,发现有以下几种方式传递参数: 一.直接把sql查询语句完整写入 ...
- MySQL中执行sql语句错误 Error Code: 1093. You can't specify target table 'car' for update in FROM clause
MySQL中执行sql语句错误 Error Code: 1093. You can't specify target table 'car' for update in FROM clause 201 ...
- EF Core 执行SQL语句和存储过程
无论ORM有多么强大,总会出现一些特殊的情况,它无法满足我们的要求.在这篇文章中,我们介绍几种执行SQL的方法. 表结构 在具体内容开始之前,我们先简单说明一下要使用的表结构. public clas ...
- Entity Framework Core 执行SQL语句和存储过程
无论ORM有多么强大,总会出现一些特殊的情况,它无法满足我们的要求.在这篇文章中,我们介绍几种执行SQL的方法. 表结构 在具体内容开始之前,我们先简单说明一下要使用的表结构. public clas ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(89)-EF执行SQL语句与存储过程
这一节,我们来看看EF如何执行SQL语句与读取存储过程的数据,可能有一部分人,还不知道EF如何执行存储过程与原生SQL语句! 我们什么时候要直接使用原生的SQL语句? 返回值过于复杂 过于复杂的联合查 ...
- Entity Framework 在MySQL中执行SQL语句,关于参数问题
在Entity Framework中添加MySQL模型,在写代码的过程中需要直接执行SQL语句. 在SQL语句中用到了@curRank := 0 这样在SQL语句中定义参数,同时还会有传入参数:ai. ...
- MySQL学习系列一---命令行连接mysql和执行sql文件
1.命令行连接mysql #mysql -h(主机) -u(用户名) -p (数据库名) mysql -hlocalhost -uroot -p testdb Enter password: **** ...
- (转载)MySQL中执行sql语句反斜杠需要进行转义否则会被吃掉
(转载)http://www.phpcode8.com/lamp/mysql-lamp/mysql-escape-slash.html 最近在执行一个sql备份的还原后,发现系统的部分路径找不到,于是 ...
随机推荐
- 201521123057 《Java程序设计》第9周学习总结
1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常相关内容. 2. 书面作业 常用异常 1.题目5-1 1.1 截图你的提交结果(出现学号) 答: 1.2 自己以前编写的代码中经 ...
- MarkDown换行
现象:1,MarkDown编辑两行显示,但是实际显示为一行: 2,编辑状态中空一行,此时显示为也空了一行,界面显示不友好: 解决:在第一行中最后输入至少2个空格+回车即可显示正常:
- C#中if_else以及for循环的简单理解
if_else语句的语法: if(判断条件) { 执行语句 }else { 执行语句 } 判断条件位true执行if大括号的语句,false执行else大括号的语句. if_else的扩展: 连续判断 ...
- JDBC中的ResultSet无法多次循环的问题。
前几天碰见了一个很奇葩的问题,使我百思不得其解,今天就写一下我遇见的问题吧,也供大家参考,别和我犯同样的毛病. 首先说下jdbc,jdbc是java是一种用于执行SQL语句的Java API,从jdb ...
- oracle 删除外键约束 禁用约束 启用约束
oracle 删除外键约束 禁用约束 启用约束 执行以下sql生成的语句即可 删除所有外键约束 Sql代码 select 'alter table '||table_name||' drop con ...
- nested exception is java.lang.IllegalArgumentException: Pointcut is not well-formed
在用AOP 的时候出现了如下的错误, 警告: Exception encountered during context initialization - cancelling refresh atte ...
- js两个叹号的使用
1.浏览器判断空和未定义以及零时返回的值如下: alert(undefined) //undefined alert(null) //null alert(0) //0 2.有时为了便于下一步判 ...
- Codeforces Round #436 (Div. 2) C. Bus
http://codeforces.com/contest/864/problem/C 题意: 坐标轴上有x = 0和 x = a两点,汽车从0到a之后掉头返回,从a到0之后又掉头驶向a...从0到a ...
- 为什么你需要将代码迁移到ASP.NET Core 2.0?
随着 .NET Core 2.0 的发布,.NET 开源跨平台迎来了新的时代.开发者们可以选择使用命令行.个人喜好的文本编辑器.Visual Studio 2017 15.3 和 Visual Stu ...
- BZOJ-1012-[JSOI2008]最大数maxnumber(线段树)
Description 现在请求你维护一个数列,要求提供以下两种操作:1. 查询操作.语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值.限制:L不超过当前数列的长度.2. 插 ...