写Secondlife智能体的知识系统小插件的时候遇到的这个问题。

在把某个NPC的全部知识复制给另一个NPC的时候,对数据库操作,为了提升一点效率希望与数据库建立一次连接,全部添加进表以后再断开连接。

于是这样写的:

MySqlCommand mycmd = new MySqlCommand();
MySqlConnection mycon = new MySqlConnection(MysqlDao.constr);//创建连接
mycmd.Connection = mycon;
MySqlDataReader myreader;
mycon.Open();
foreach(Knowledge tk in KnowledgeList)
{
  insertSql = "INSERT INTO ...);";
  mycmd.CommandText = insertSql;
  res = mycmd.ExecuteNonQuery();   mycmd.CommandText = "select ... from ...";
  myreader = mycmd.ExecuteReader();
  myreader.Read();
int kid = int.Parse(myreader.GetString("..."));
//...
}
mycon.Close();

用到DataReader的原因:因为mysql的自增序号会将插入修改等操作全部计数在内,所以每次插入以后需要立即反查刚才这个序号,在拿到程序里使用。

结果发现报错:There is already an open DataReader associated with this Connection which must be closed first.

但是如果不用DataReader,只插入删除修改的话是没事的,上CSDN看到大牛回答DataReader这货是独占Connection的。。可以在把它的属性加一个MultipleActiveResultSets=True,看到这里的小白我兴高采烈的跑去改:


MysqlDao.constr = "server=localhost;User Id=root;password=****;Database=...;MutipleActiveResultSets=True";

然后欢快的跑起来,跪了。

于是才知道,SqlServer里才有这个属性,Mysql里没有。。。

所以很遗憾,看来DataReader每次用完了必须关掉。。。

最后代码就不展示了,仅仅把open()和close()都放进循环就好了。。为了功能,抛弃了效率T^T。

啊!刚才问了crccw和Araleii,表示可以只把DataReader给dispose就可以:

MySqlCommand mycmd = new MySqlCommand();
MySqlConnection mycon = new MySqlConnection(MysqlDao.constr);//创建连接
mycmd.Connection = mycon;
MySqlDataReader myreader;
mycon.Open();
foreach(Knowledge tk in KnowledgeList)
{
  insertSql = "INSERT INTO ...);";
  mycmd.CommandText = insertSql;
  res = mycmd.ExecuteNonQuery();   mycmd.CommandText = "select ... from ...";
  myreader = mycmd.ExecuteReader();
  myreader.Read();
int kid = int.Parse(myreader.GetString("..."));
  myreader.dispose();//只要加这句就可以了
}
mycon.Close();

Mysql的MySqlDataReader对于MysqlConnection是独占式的更多相关文章

  1. SVN 使用锁实现独占式签出

      SVN默认并行工作,但是自动合并又做得很渣.团队工作中,如果确实有一些文件希望独占式签出可以使用SVN的特别属性.       Subversion针对此问题的解决方案是提供一种机制,提醒用户在开 ...

  2. TFS2008解除独占式锁定文件命令(转载)

    使用场景:如果项目团队成员A对项目某个文件以独占式方式签出,恰好那天该成员A没有来上班而成员需要对此文件进入修改并check in,这时需要先把A对该文件的锁定解除.没有IDE可以使用,只能使用下面的 ...

  3. C# 制作Java +Mysql+Tomcat 环境安装程序,一键式安装

    原文:C# 制作Java +Mysql+Tomcat 环境安装程序,一键式安装 要求: JDK.Mysql.Tomcat三者制作成一个安装包, 不能单独安装,安装过程不显示三者的界面, 安装完成要配置 ...

  4. Java并发包源码学习系列:AQS共享式与独占式获取与释放资源的区别

    目录 Java并发包源码学习系列:AQS共享模式获取与释放资源 独占式获取资源 void acquire(int arg) boolean acquireQueued(Node, int) 独占式释放 ...

  5. MySQL SQL优化之字符串索引隐式转换

    之前有用户很不解:SQL语句非常简单,就是select * from test_1 where user_id=1 这种类型,而且user_id上已经建立索引了,怎么还是查询很慢? test_1的表结 ...

  6. MySQL中间件之ProxySQL(11):链式规则( flagIN 和 flagOUT )

    返回ProxySQL系列文章:http://www.cnblogs.com/f-ck-need-u/p/7586194.html 1.理解链式规则 在mysql_query_rules表中,有两个特殊 ...

  7. AQS独占式同步队列入队与出队

    入队 Node AQS同步队列和等待队列共用同一种节点结构Node,与同步队列相关的属性如下. prev 前驱结点 next 后继节点 thread 入队的线程 入队节点的状态 INITIAl 0 初 ...

  8. MySQL解惑——GROUP BY隐式排序

    MySQL中GROUP BY隐式排序是什么概念呢? 主要是其它RDBMS没有这样的概念,如果没有认真了解过概念,对这个概念会感觉有点困惑,我们先来看看官方文档的介绍: 官方文档MySQL 5.7 Re ...

  9. MySQL解惑——GROUP BY隐式排序

    原文:MySQL解惑--GROUP BY隐式排序 MySQL中GROUP BY隐式排序是什么概念呢? 主要是其它RDBMS没有这样的概念,如果没有认真了解过概念,对这个概念会感觉有点困惑,我们先来看看 ...

随机推荐

  1. ENC28j60以太网芯片驱动程序简介

    ENC28j60以太网芯片驱动程序简介 ENC28J60 驱动开发要点 enc28J60 和 Arduino (1)——ping通你的Arduino MCU51单片机uIP协议栈+ENC28J60网卡 ...

  2. php fsockopen

    1.PHP fsockopen函数说明: Open Internet or Unix domain socket connection(打开套接字链接) Initiates a socket conn ...

  3. C 汇编代码 函数调用指令和栈平衡

    1. CALL指令: CALL指令可不是如唤指令,而是子程序调用指令.那么汇编语言中的子程序是什么呢?子程序能被其它程序调用,在实现某种功能后能自动返回到调用程序去的程序.其最后一条指令一定是返回指令 ...

  4. margin

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  5. Mysql笔记4数据表操作1

    1查看表的结构 (1)show create table +数据库名称 (2)desc+数据库名称 2修改表 (1)表中添加列 alter table 数据库名称 add column addr va ...

  6. ViewPager滑动标签-PagerSlidingTabStrip的使用

    有篇博客写的已经非常详细,所以不再写了.主要在于导入这个Library,导入Library看自己的笔记 博客地址:http://doc.okbase.net/HarryWeasley/archive/ ...

  7. Spring注解基本解读

    在一个类中使用Spring对象,办法如下: 使用注解的形式注入 从ApplicationContext中获取. T t = new ApplicationContext.getBean("x ...

  8. int *p[4]与int (*q)[4]的区别

    以上定义涉及两个运算符:“*”(间接引用).“[]”(下标),“[]”的优先级别大于“*”的优先级别. 首先看int *p[4],“[]”的优先级别高,所以它首先是个大小为4的数组,即p[4]:剩下的 ...

  9. Django: 之Apache、Nginx部署以及发送邮件

    在这里讲述部署的方法和常见的问题,并给出了在BAE,JAE,SAE等上面部署的实例. Django + nginx + Gunicorn/uwsgi部署方式,参见另一篇:Django部署(nginx) ...

  10. Entity Framework 学习初级篇6--EntityClient

    System.Data.EntityClient 命名空间是 实体框架的 .NET Framework 数据提供程序.EntityClient 提供程序使用存储特定的 ADO.NET 数据提供程序类和 ...