视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
SQLSERVER中的MARS结果集是什么东东
2020-11-09 07:26:34 责编:小采
文档

MARS:多个活动结果集 MSDN上的解释: SQL Server 2005 在访问数据库引擎的应用程序中引入了对多个活动结果集 (MARS) 的支持。在 SQL Server 的早期版本中,数据库应用程序无法在单个连接上保持多个活动语句。使用 SQL Server 默认结果集时,应用程序必须先

MARS:多个活动结果集

MSDN上的解释:

SQL Server 2005 在访问数据库引擎的应用程序中引入了对多个活动结果集 (MARS) 的支持。在 SQL Server 的早期版本中,数据库应用程序无法在单个连接上保持多个活动语句。使用 SQL Server 默认结果集时,应用程序必须先处理或取消自某一批处理生成的所有结果集,然后才能执行该连接上的其他任何批处理。SQL Server 2005 引入了新连接属性,支持应用程序在每个连接上拥有多个待定请求,特别是支持每个连接具有多个活动的默认结果集。

MARS 通过以下新功能简化了应用程序设计:

  • 应用程序可以同时打开多个默认结果集,并且交错读取它们。

  • 应用程序可以在默认结果集打开的同时执行其他语句(例如 INSERT、UPDATE、DELETE 和存储过程调用)。

  • 下列指南对使用 MARS 的应用程序很有帮助:

  • 默认结果集应该用于使用单个 SQL 语句(SELECT、带 OUTPUT 的 DML、RECEIVE、READ TEXT 等)生成的短期或较小结果集。

  • 服务器游标应该用于使用单个 SQL 语句生成的长期或较大结果集。

  • 对于过程请求(不论它们是否返回结果)以及返回多个结果的批处理,应始终读取到它们的结果的末尾。

  • 尽可能使用 API 调用(而不是 Transact-SQL 语句)更改连接属性和管理事务。

  • 在 MARS 中,有多个批处理并发运行时禁止会话范围内的模拟。

  • 在SQL2000的时候,一个连接同时只能运行一个批处理指令。也就是说一个连接在一个时间点只能有一个请求在运行。

    但是SQL2005以后,如果使用了MARS技术,一个连接可以同时开启多个结果集。而sys.sysprocesses视图不能
    正确显示这种行为。

    MARS的执行方式:

    MARS 是从交错执行而不是从并行执行的角度定义的

    如何在不同的数据访问接口里使用MARS技术

    如果使用SQL Server Native Client OLE DB 访问接口 ADO跟ADO.NET就是使用这个接口

    那么 连接字符串可以是这样:

    1 string connstr = "Server=(local);Database=AdventureWorks;User ID=sa;Password=test;MarsConn=true";

    如果使用SQL Server Native Client ODBC 驱动程序 的话

    那么连接字符串可以是这样:

    1 SQLSetConnectAttr(hdbc, SQL_COPT_SS_MARS_ENABLED, SQL_MARS_ENABLED_YES, SQL_IS_UINTEGER);
    2 SQLDriverConnect(hdbc, hwnd,"DRIVER=SQL Server Native Client 10.0;SERVER=(local);trusted_connection=yes;", SQL_NTS, szOutConn, MAX_CONN_OUT, &cbOutConn, SQL_DRIVER_COMPLETE);

    下载本文
    显示全文
    专题