如何通过控制台链接oracle内存数据库,并创建c#sqlserver存储过程程

怎么样写个c#sqlserver存储过程程 把一张表嘚数据加载到内存缓存起来

我查了下 说是定义数组就可以。得定义带下标的数组 求各位大神指点迷津 。。大恩不言谢了

【IT专家网独家】随着过去三十年

關系型数据库管理系统的发展它提供给数据库管理员几个选项将经常被访问的数据保存在内存中以减少或消除从数据库的I/O子系统读取不必要的数据。下面是使数据库管理员可以在她的工具中找到的一些特性的快速概览这些特性帮助维护对查询数据库内存中相关数据的良恏控制。

  持久缓存数据库块 CACHE 存储选项(还提供了+CACHE优化器提示)提供了一个为数据表保存所有数据库块的方法,只要这个表被表扫描进数據库缓存区中一旦通过这个方法进行了缓存区,相关的缓存就绝不会从缓存区中过期直到数据库实例终止。这个策略有一些缺陷因為它依赖于数据库管理员对哪个表最能受益于缓存的了解,它还倾向于作为一个用于编码表和参照数据的万用解决方法而被过度使用

  影响数据库块的保存持久性。Oracle还通过创建或改变一个表或索引以便它保存在这个缓存池中从而提供了影响缓存保持在数据库缓存区中嘚KEEP缓存池中的能力。Oracle只是简单的将缓存尽可能长时间的保存在KEEP池中;本质上来说它们放置在缓存中更接近最常使用(MRU)的一端。但是没有什麼是永远的,当大型查询需要大量缓存来完成时就可能使KEEP缓存池中的缓存最终过期。

  永久地保存结果集物化视图(MV)提供了一个保存經常查询的数据的方法:通过创建一个具有基本表的视图来保存一个特定记录集一段较长时间的能力。如果配置适当Oracle将“重写”一个现囿查询以便它查询物化视图而不是直接查询基本的数据库表。此外可以建立一个物化视图以便对它的基本基础数据的改变可以自动地对依赖的物化视图进行更新。但是物化视图的最明显优势也是它的潜在危害:因为它需要定期地进行更新以保证它的数据是最新的,数据嘚实际刷新可能花费额外的时间甚至有可能发生在很不恰当的时刻。

  我们真正需要的是持久性比这些特性短一些的东西(仍然很出色!):一段只存储一个查询结果的内存它可以与任何其它需要相似数据的存储共享。例如一个“编码表”捕捉U.S.各州和土地面积,它可能只昰一个具有几行和几列的表并且几乎都不改变,所以它应该很少需要被更新因此,当这个结果集不再有效时我希望它可以自己更新洏不需要我进行任何干预。那么经常被几个用户频繁执行、但不经常利用物化视图的查询重写功能的查询怎么样呢?物化视图在创建、配置囷刷新方面不是那么简单所以这个特性需要比物化视图更易于建立,而且必须能够只花费几分钟的执行耗费来刷新它本身

  SQL查询结果集缓存

  Oracle Database 11g提供了结果集缓存来提供这个功能。一个SQL查询结果集将取决于几个新的初始化参数的设置被缓存在共享全局区(SGA)的一个数据庫实例共享池的子段中。

  •   当设置为MANUAL(默认)时如果查询本身指定了+RESULT_CACHE优化器提示,那么一个SQL查询结果将只被认为是可能被缓存
  •   但是洳果这个参数设置为FORCE,那么查询的结果将总是被缓存除非这个查询指定了+NO_RESULT_CACHE优化器提示。
  •   最后如果这个参数设置为了AUTO,那么Oracle 11g使用一個未发布的内部算法来自动地根据结果集从未来语句执行受益频繁度来决定查询结果集是否应该被缓存只有当这个查询指定了+NO_RESULT_CACHE优化器提礻时它才会被忽略。

  控制结果集缓存内存的利用Oracle 11g还提供了几个方法来限制使得分配给SQL查询结果集缓存的内存数量是合适的:

  RESULT_CACHE_MAX_SIZE。為所有的本地结果缓存预留适当的SGA内存量数据库管理员可以为RESULT_CACHE_MAX_SIZE初始参数指定一个数值。Oracle 11g自动地将这个提供的数值四舍五入到最接近的32K界限

  如果没有提供数值,那么Oracle 11g使用下面的算法来为结果缓存分配内存:

  注意无论使用哪个算法,Oracle 11g都不会将RESULT_CACHE_MAX_SIZE设置为超过SHARED_POOL_SIZE的75%此外,要注意如果数据库管理员想使SQL结果缓存特性完全失效那么她仅仅需要设置这个内存分配空间规模为0来告诉Oracle 11g不为结果缓存保留任何内存涳间。

  RESULT_CACHE_MAX_RESULT 这个参数告诉Oracle 11g每个单个查询应该允许多少结果缓存。它的默认值是整个结果缓存的5%这通常应该是足够的,但是它也可以设置为0%到100%

RESULT_CACHE_REMOTE_EXPIRATION。 如果一个查询依赖于一个远程数据库那么这个参数决定一个结果集应该保留的分钟数。默认数值为0分钟这是作为对远程数據库表的任何改变不能在本地数据库检测到的一个提醒,因此陈旧的结果集可能会不适当地保持一段较长时间这个参数可以设置为全局(ALTER SYSTEM)戓对每个会话(ALTER SESSION)。

  创建SQL查询结果缓存:一个简要的示例

  在Listing1.1中是关于怎样在MANUAL模式中使用SQL查询结果缓存特性的一个实际例子:

  •   首先使用DBMS_RESULT_CACHE.PURGE(看下一节的详细描述)净化结果缓存,激活MANUAL结果缓存然后将结果缓存的规模设置得相对较小,只有1MB
  •   然后用一个SQL查询从销售历史(SH)架构的PROMOTIONS表内容中捕捉一个关于总的和平均的提升成本的摘要级别表示。这个结果记录设置从源表超过500条的记录中捕捉不超过10条的记录所以它对于SQL查询结果缓存是个较好的候选方式。
  •   然后对原始的查询使用一个EXPLAIN PLAN包括+RESULT_CACHE提示以便可以决定这个刚刚创建的结果缓存是否应該被以后的查询利用。它还创建了一个报表详细地显示了结果缓存的内存是怎样被使用的。这是这个输出的一个示例:

  设置结果缓存模式为FORCE是怎样影响SQL查询结果缓存的当前内容的呢?Listing 1.2中的代码做了描述:

  •   首先激活结果缓存的FORCE模式然后将结果缓存的规模设置为相对較大的20MB,并允许单独结果缓存的最大规模为这个数值的一半(10MB)
  •   接下来,使用一个简单的SQL查询从可支付帐户测试数据中的AP.VENDORS表捕捉所有零售商的名称因为这个查询不包括+NO_RESULT_CACHE优化器指示,所以这个结果集将会立即被缓存
  •   然后用一个SQL查询捕捉可支付帐户(AP)测试数据的一个更加复杂的摘要级别表示。因为结果记录集合并了+NO_RESULT_CACHE优化器指示所以这个结果集不会被缓存。
  •   最后一步是对这两个查询使用一个EXPLAIN PLAN来看对任何将来类似产生的结果集的影响它还重新创建了结果缓存内存的详细报表来看看是否有什么改变了:

  Oracle 11g还提供了DBMS_RESULT_CACHE包来查询SQL结果缓存內容的状态和适当地控制SQL结果缓存内容。这是关于它的功能的一个简要摘要:

返回结果缓存的当前状态值包括:

ENABLED:结果缓存是激活的。

DISABLED:结果缓存是不可用的

BYPASSED:结果缓存暂时不可用。

SYNC: 结果缓存是可用的但是目前正与其他RAC节点重新同步。

列出结果缓存内存利用的一个概要(默认)或详细的报表

推出整个结果缓存的内容。

使结果缓存中一个特定对象的缓存结果无效

根据缓存ID使一特定结果缓存无效。

  Listing 1.3 显示了一些关于怎样使用这些打包的c#sqlserver存储过程程和函数的额外例子

  四个动态视图提供了关于现有结果缓存内容、内存利用和结果缓存所依赖的数据库对象的信息:

罗列出各种缓存设置和内存使用统计数据。

列出所有的内存块和相应的统计信息

列出所有的对象(緩存的结果和依赖的对象)和它们的属性。

列出缓存的结果和依赖对象间的依赖详情

  Listing 1.4是用于这篇文章单个示例(V$)的几个查询;扩展这些查询成为用于Real Application Clusters数据库的全局资源视图(GV$)是比较简单的工作。在Listing 1.5中重新生成了对V$RESULT_CACHE_OBJECTS视图查询的结果,以此来描述它为缓存的结果集包含了什么え数据

  Oracle 11g新的结果缓存功能为数据库管理员提供了几个简单但很好的工具来捕捉、保存、监控和管理SQL查询结果缓存,加速了应用程序對相应持久数据的访问速度在这个系列文章中的最后一篇中,我将介绍怎样在PL/SQL函数中利用结果集缓存还有怎样在应用程序服务器级别來缓存结果集以便加快客户端应用程序对频繁访问数据的访问。

查询结果集cache 谷歌

我要回帖

更多关于 c#sqlserver存储过程 的文章

 

随机推荐