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语句 和存储过程?的更多相关文章

  1. JDBC连接MYSQL,批量执行SQL语句或在执行一个SQL语句之前执行一个SQL语句

    conn = MysqlJdbcUtils.getConnection(); Statement ps=conn.createStatement(); ps.addBatch("trunca ...

  2. Python连接MySQL数据库执行sql语句时的参数问题

    由于工作需要,今天写了一个Python小脚本,其中需要连接MySQL数据库,在执行sql命令时需要传递参数,结果出问题了.在网上查了一下,发现有以下几种方式传递参数: 一.直接把sql查询语句完整写入 ...

  3. 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 ...

  4. EF Core 执行SQL语句和存储过程

    无论ORM有多么强大,总会出现一些特殊的情况,它无法满足我们的要求.在这篇文章中,我们介绍几种执行SQL的方法. 表结构 在具体内容开始之前,我们先简单说明一下要使用的表结构. public clas ...

  5. Entity Framework Core 执行SQL语句和存储过程

    无论ORM有多么强大,总会出现一些特殊的情况,它无法满足我们的要求.在这篇文章中,我们介绍几种执行SQL的方法. 表结构 在具体内容开始之前,我们先简单说明一下要使用的表结构. public clas ...

  6. ASP.NET MVC5+EF6+EasyUI 后台管理系统(89)-EF执行SQL语句与存储过程

    这一节,我们来看看EF如何执行SQL语句与读取存储过程的数据,可能有一部分人,还不知道EF如何执行存储过程与原生SQL语句! 我们什么时候要直接使用原生的SQL语句? 返回值过于复杂 过于复杂的联合查 ...

  7. Entity Framework 在MySQL中执行SQL语句,关于参数问题

    在Entity Framework中添加MySQL模型,在写代码的过程中需要直接执行SQL语句. 在SQL语句中用到了@curRank := 0 这样在SQL语句中定义参数,同时还会有传入参数:ai. ...

  8. MySQL学习系列一---命令行连接mysql和执行sql文件

    1.命令行连接mysql #mysql -h(主机) -u(用户名) -p (数据库名) mysql -hlocalhost -uroot -p testdb Enter password: **** ...

  9. (转载)MySQL中执行sql语句反斜杠需要进行转义否则会被吃掉

    (转载)http://www.phpcode8.com/lamp/mysql-lamp/mysql-escape-slash.html 最近在执行一个sql备份的还原后,发现系统的部分路径找不到,于是 ...

随机推荐

  1. 201521123078 《Java程序设计》第14周学习总结

    1. 本周学习总结 2. 书面作业 1. MySQL数据库基本操作 建立数据库,将自己的姓名.学号作为一条记录插入.(截图,需出现自己的学号.姓名) 在自己建立的数据库上执行常见SQL语句(截图) 2 ...

  2. Java:类类型变量

    在java中有一种被称为类类型的变量,它不同于基本类型变量存储值的方式.不管是基本变量还是类类型变量,都实现为一个内存位置.但是,由于基本变量所需的内存数量是相同的,所以系统可以给它设置一个固定的空间 ...

  3. Excel表科学记数法的数字和文本的转换

    一,科学记数法的数字转换文本类型: 1,还未有数据,先选中列或者单元格 右键单击->设置单元格格式->文本->确定 2,已有数据,先选中列或者单元格 右键单击->设置单元格格式 ...

  4. 将Editplus添加到右键打开菜单

    因为自己一直用Editplus作为文本打开工具,新的电脑将压缩文件复制了过来,但是没有右键打开了. 第一打开注册表 在命令框中输入regedit 第二在注册表中输入选项 如下图所示在下拉菜单中新建Ed ...

  5. oracle 表查询(二)

    1.使用逻辑操作符号问题:查询工资高于500或者是岗位为manager的雇员,同时还要满足他们的姓名首字母为大写的J?select * from emp where (sal > 500 or ...

  6. PyTorch教程之Autograd

    在PyTorch中,autograd是所有神经网络的核心内容,为Tensor所有操作提供自动求导方法. 它是一个按运行方式定义的框架,这意味着backprop是由代码的运行方式定义的. 一.Varia ...

  7. TETeLasr Cutting System 开机回零问题

    TETeLasr Cutting System 开机回零问题    :打开 "轴信息"    :打开 加工参数-->机器参数-->脉冲当量: X轴==4000 Y轴== ...

  8. Problem 2144 Shooting Game fzu

    Problem 2144 Shooting Game Accept: 99    Submit: 465Time Limit: 1000 mSec    Memory Limit : 32768 KB ...

  9. POJ1032 Parliament(数论)

    New convocation of The Fool Land's Parliament consists of N delegates. According to the present regu ...

  10. R语言包下载(转载)

    http://blog.csdn.net/hongjinlongno1/article/details/53130893 包含几乎所有包,很方便