~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/optimizer/range.h

[patch 125/129] Merge patch for revision 1943 from InnoDB SVN:
revno: 1943
revision-id: svn-v4:16c675df-0fcb-4bc9-8058-dcc011a37293:branches/zip:6207
parent: svn-v4:16c675df-0fcb-4bc9-8058-dcc011a37293:branches/zip:6202
committer: vasil
timestamp: Fri 2009-11-20 08:19:14 +0000
message:
  branches/zip: Merge r6198:6206 from branches/5.1:
  
  (r6203 was skipped as it is already in branches/zip)
  
    ------------------------------------------------------------------------
    r6200 | vasil | 2009-11-19 12:14:23 +0200 (Thu, 19 Nov 2009) | 4 lines
    Changed paths:
       M /branches/5.1/btr/btr0btr.c
    
    branches/5.1:
    
    White space fixup - indent under the opening (
    
    ------------------------------------------------------------------------
    r6203 | jyang | 2009-11-19 15:12:22 +0200 (Thu, 19 Nov 2009) | 8 lines
    Changed paths:
       M /branches/5.1/btr/btr0btr.c
    
    branches/5.1: Use btr_free_root() instead of fseg_free() for
    the fix of bug #48469, because fseg_free() is not defined
    in the zip branch. And we could save one mini-trasaction started
    by fseg_free().
    
    Approved by Marko.
    
    
    ------------------------------------------------------------------------
    r6205 | jyang | 2009-11-20 07:55:48 +0200 (Fri, 20 Nov 2009) | 11 lines
    Changed paths:
       M /branches/5.1/handler/ha_innodb.cc
    
    branches/5.1: Add a special case to handle the Duplicated Key error
    and return DB_ERROR instead. This is to avoid a possible SIGSEGV
    by mysql error handling re-entering the storage layer for dup key
    info without proper table handle.
    This is to prevent a server crash when error situation in bug
    #45961 "DDL on partitioned innodb tables leaves data dictionary
    in an inconsistent state" happens.
    
    rb://157 approved by Sunny Bains.
    
    
    ------------------------------------------------------------------------
    r6206 | jyang | 2009-11-20 09:38:43 +0200 (Fri, 20 Nov 2009) | 5 lines
    Changed paths:
       M /branches/5.1/handler/ha_innodb.cc
    
    branches/5.1: Fix a minor code formating issue for 
    the parenthesis iplacement of the if condition in
    rename_table().
    
    
    ------------------------------------------------------------------------
modified:
  handler/ha_innodb.cc           2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fhandler%2Fha_innodb.cc
diff:
=== modified file 'handler/ha_innodb.cc'

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
3
 *
4
 
 *  Copyright (C) 2008-2009 Sun Microsystems, Inc.
 
4
 *  Copyright (C) 2008-2009 Sun Microsystems
5
5
 *
6
6
 *  This program is free software; you can redistribute it and/or modify
7
7
 *  it under the terms of the GNU General Public License as published by
22
22
#ifndef DRIZZLED_OPTIMIZER_RANGE_H
23
23
#define DRIZZLED_OPTIMIZER_RANGE_H
24
24
 
25
 
#include <drizzled/field.h>
26
 
#include <drizzled/item/sum.h>
27
 
#include <drizzled/table_reference.h>
 
25
#include "drizzled/field.h"
 
26
#include "drizzled/item/sum.h"
28
27
 
29
28
#include <queue>
30
29
 
31
 
#include <boost/dynamic_bitset.hpp>
32
 
 
33
30
namespace drizzled
34
31
{
35
32
 
241
238
   * 
242
239
   * @note This is used by during explain plan.
243
240
   */
244
 
  virtual void add_keys_and_lengths(std::string *key_names,
245
 
                                    std::string *used_lengths)=0;
 
241
  virtual void add_keys_and_lengths(String *key_names, String *used_lengths)=0;
246
242
 
247
243
  /**
248
244
   * Append text representation of quick select structure (what and how is
253
249
   * This function is implemented only by quick selects that merge other quick
254
250
   * selects output and/or can produce output suitable for merging.
255
251
   */
256
 
  virtual void add_info_string(std::string *)
 
252
  virtual void add_info_string(String *) 
257
253
  {}
258
 
 
 
254
  
259
255
  /**
260
256
   * Returns true if any index used by this quick select
261
257
   * uses field which is marked in passed bitmap.
262
258
   */
263
 
  virtual bool is_keys_used(const boost::dynamic_bitset<>& fields);
 
259
  virtual bool is_keys_used(const MyBitmap *fields);
264
260
};
265
261
 
266
262
struct st_qsel_param;
316
312
};
317
313
 
318
314
QuickRangeSelect *get_quick_select_for_ref(Session *session, 
319
 
                                           Table *table,
320
 
                                           table_reference_st *ref,
321
 
                                           ha_rows records);
 
315
                                             Table *table,
 
316
                                             struct table_reference_st *ref,
 
317
                                             ha_rows records);
322
318
 
323
319
/*
324
320
  Create a QuickRangeSelect from given key and SEL_ARG tree for that key.
349
345
                                   uint32_t mrr_buf_size, 
350
346
                                   memory::Root *alloc);
351
347
 
352
 
uint32_t get_index_for_order(Table *table, Order *order, ha_rows limit);
 
348
uint32_t get_index_for_order(Table *table, order_st *order, ha_rows limit);
353
349
 
354
350
SqlSelect *make_select(Table *head, 
355
351
                       table_map const_tables,