始创于2000年 股票代码:831685
咨询热线:0371-60135900 注册有礼 登录
  • 挂牌上市企业
  • 60秒人工响应
  • 99.99%连通率
  • 7*24h人工
  • 故障100倍补偿
您的位置: 网站首页 > 帮助中心>文章内容

为存储引擎添加对INSERT的支持

发布时间:  2012/8/23 16:51:04

一旦在你的存储引擎中有了读支持,下一个需要实施的特性是对INSERT语句的支持。有了INSERT支持,存储引擎就能处理WORM(写一次,读多次)应用程序,如用于以后分析的日志和归档应用等。 电脑维护www.boydavid.com

所有的INSERT操作均是通过write_row()函数予以处理的:电脑知识www.boydavid.com

int ha_foo::write_row(byte *buf)    

*buf参数包含将要插入的行,采用内部MySQL格式。基本的存储引擎将简单地前进到数据文件末尾,并直接在末尾处添加缓冲的内容,这样就能使行读取变得简单,这是因为,你可以读取行并将其直接传递到rnd_next()函数的缓冲参数中。 电脑入门www.boydavid.com

写入行的进程与读取行的进程相反:从MySQL内部行格式获取数据,并将其写入数据文件。下述示例来自CSV存储引擎: 电脑常识www.boydavid.com

int ha_tina::write_row(byte * buf) 电脑技术www.boydavid.com 
 {  
   int size;  
   DBUG_ENTER("ha_tina::write_row");  
   
   statistic_increment(table->in_use->status_var.ha_write_count, &LOCK_status);  
   
   if (table->timestamp_field_type & TIMESTAMP_AUTO_SET_ON_INSERT)  
     table->timestamp_field->set_time();  
   
   size= encode_quote(buf);  
   
   if (my_write(share->data_file, buffer.ptr(), size, MYF(MY_WME | MY_NABP)))  
     DBUG_RETURN(-1);  
   
   if (get_mmap(share, 0) > 0)  
     DBUG_RETURN(-1); 电脑技术www.boydavid.com 
   DBUG_RETURN(0);  
 }  

前述示例中的两条注释包括,更新关于写入操作的表统计,以及在写入行之前设置时间戳。


本文出自:亿恩科技【www.enkj.com】

服务器租用/服务器托管中国五强!虚拟主机域名注册顶级提供商!15年品质保障!--亿恩科技[ENKJ.COM]

  • 您可能在找
  • 亿恩北京公司:
  • 经营性ICP/ISP证:京B2-20150015
  • 亿恩郑州公司:
  • 经营性ICP/ISP/IDC证:豫B1.B2-20060070
  • 亿恩南昌公司:
  • 经营性ICP/ISP证:赣B2-20080012
  • 服务器/云主机 24小时售后服务电话:0371-60135900
  • 虚拟主机/智能建站 24小时售后服务电话:0371-60135900
  • 专注服务器托管17年
    扫扫关注-微信公众号
    0371-60135900
    Copyright© 1999-2019 ENKJ All Rights Reserved 亿恩科技 版权所有  地址:郑州市高新区翠竹街1号总部企业基地亿恩大厦  法律顾问:河南亚太人律师事务所郝建锋、杜慧月律师   京公网安备41019702002023号
      0
     
     
     
     

    0371-60135900
    7*24小时客服服务热线