Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
7b81a9fd
Commit
7b81a9fd
authored
Mar 25, 2005
by
brian@zim.(none)
Browse files
Options
Browse Files
Download
Plain Diff
Merging support for blackhole up to 5.0.
parents
97b5cbba
6e2caeb0
Changes
13
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
488 additions
and
4 deletions
+488
-4
configure.in
configure.in
+1
-0
mysql-test/include/have_blackhole.inc
mysql-test/include/have_blackhole.inc
+4
-0
mysql-test/r/blackhole.result
mysql-test/r/blackhole.result
+86
-0
mysql-test/r/have_blackhole.require
mysql-test/r/have_blackhole.require
+2
-0
mysql-test/t/blackhole.test
mysql-test/t/blackhole.test
+99
-0
sql/Makefile.am
sql/Makefile.am
+2
-3
sql/ha_blackhole.cc
sql/ha_blackhole.cc
+188
-0
sql/ha_blackhole.h
sql/ha_blackhole.h
+88
-0
sql/handler.cc
sql/handler.cc
+9
-0
sql/handler.h
sql/handler.h
+1
-1
sql/mysql_priv.h
sql/mysql_priv.h
+1
-0
sql/mysqld.cc
sql/mysqld.cc
+6
-0
sql/set_var.cc
sql/set_var.cc
+1
-0
No files found.
configure.in
View file @
7b81a9fd
...
@@ -2377,6 +2377,7 @@ MYSQL_CHECK_INNODB
...
@@ -2377,6 +2377,7 @@ MYSQL_CHECK_INNODB
MYSQL_CHECK_EXAMPLEDB
MYSQL_CHECK_EXAMPLEDB
MYSQL_CHECK_ARCHIVEDB
MYSQL_CHECK_ARCHIVEDB
MYSQL_CHECK_CSVDB
MYSQL_CHECK_CSVDB
MYSQL_CHECK_BLACKHOLEDB
MYSQL_CHECK_NDBCLUSTER
MYSQL_CHECK_NDBCLUSTER
MYSQL_CHECK_FEDERATED
MYSQL_CHECK_FEDERATED
...
...
mysql-test/include/have_blackhole.inc
0 → 100644
View file @
7b81a9fd
--
require
r
/
have_blackhole
.
require
disable_query_log
;
show
variables
like
"have_blackhole_engine"
;
enable_query_log
;
mysql-test/r/blackhole.result
0 → 100644
View file @
7b81a9fd
drop table if exists t1,t2;
CREATE TABLE t1 (
Period smallint(4) unsigned zerofill DEFAULT '0000' NOT NULL,
Varor_period smallint(4) unsigned DEFAULT '0' NOT NULL
) ENGINE=blackhole;
INSERT INTO t1 VALUES (9410,9412);
select period from t1;
period
select * from t1;
Period Varor_period
select t1.* from t1;
Period Varor_period
CREATE TABLE t2 (
auto int NOT NULL auto_increment,
fld1 int(6) unsigned zerofill DEFAULT '000000' NOT NULL,
companynr tinyint(2) unsigned zerofill DEFAULT '00' NOT NULL,
fld3 char(30) DEFAULT '' NOT NULL,
fld4 char(35) DEFAULT '' NOT NULL,
fld5 char(35) DEFAULT '' NOT NULL,
fld6 char(4) DEFAULT '' NOT NULL,
primary key (auto)
) ENGINE=blackhole;
INSERT INTO t2 VALUES (1192,068305,00,'Colombo','hardware','colicky','');
INSERT INTO t2 VALUES (1193,000000,00,'nondecreasing','implant','thrillingly','');
select t2.fld3 from t2 where companynr = 58 and fld3 like "%imaginable%";
fld3
select fld3 from t2 where fld3 like "%cultivation" ;
fld3
select t2.fld3,companynr from t2 where companynr = 57+1 order by fld3;
fld3 companynr
select fld3,companynr from t2 where companynr = 58 order by fld3;
fld3 companynr
select fld3 from t2 order by fld3 desc limit 10;
fld3
select fld3 from t2 order by fld3 desc limit 5;
fld3
select fld3 from t2 order by fld3 desc limit 5,5;
fld3
select t2.fld3 from t2 where fld3 = 'honeysuckle';
fld3
select t2.fld3 from t2 where fld3 LIKE 'honeysuckl_';
fld3
select t2.fld3 from t2 where fld3 LIKE 'hon_ysuckl_';
fld3
select t2.fld3 from t2 where fld3 LIKE 'honeysuckle%';
fld3
select t2.fld3 from t2 where fld3 LIKE 'h%le';
fld3
select t2.fld3 from t2 where fld3 LIKE 'honeysuckle_';
fld3
select t2.fld3 from t2 where fld3 LIKE 'don_t_find_me_please%';
fld3
select t2.fld3 from t2 where fld3 >= 'honeysuckle' and fld3 <= 'honoring' order by fld3;
fld3
select fld1,fld3 from t2 where fld3="Colombo" or fld3 = "nondecreasing" order by fld3;
fld1 fld3
DROP TABLE t1;
CREATE TABLE t1 (a VARCHAR(200), b TEXT, FULLTEXT (a,b));
INSERT INTO t1 VALUES('MySQL has now support', 'for full-text search'),
('Full-text indexes', 'are called collections'),
('Only MyISAM tables','support collections'),
('Function MATCH ... AGAINST()','is used to do a search'),
('Full-text search in MySQL', 'implements vector space model');
SHOW INDEX FROM t1;
Table Non_unique Key_name Seq_in_index Column_name Collation Cardinality Sub_part Packed Null Index_type Comment
t1 1 a 1 a NULL NULL NULL NULL YES FULLTEXT
t1 1 a 2 b NULL NULL NULL NULL YES FULLTEXT
select * from t1 where MATCH(a,b) AGAINST ("collections");
a b
Only MyISAM tables support collections
Full-text indexes are called collections
explain extended select * from t1 where MATCH(a,b) AGAINST ("collections");
id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE t1 fulltext a a 0 1 Using where
Warnings:
Note 1003 select test.t1.a AS `a`,test.t1.b AS `b` from test.t1 where (match test.t1.a,test.t1.b against (_latin1'collections'))
select * from t1 where MATCH(a,b) AGAINST ("indexes");
a b
Full-text indexes are called collections
select * from t1 where MATCH(a,b) AGAINST ("indexes collections");
a b
Full-text indexes are called collections
Only MyISAM tables support collections
select * from t1 where MATCH(a,b) AGAINST ("only");
a b
drop table if exists t1,t2;
mysql-test/r/have_blackhole.require
0 → 100644
View file @
7b81a9fd
Variable_name Value
have_blackhole_engine YES
mysql-test/t/blackhole.test
0 → 100644
View file @
7b81a9fd
#
# Simple test for blackhole example
# Taken from the select test
#
--
source
include
/
have_blackhole
.
inc
--
disable_warnings
drop
table
if
exists
t1
,
t2
;
--
enable_warnings
CREATE
TABLE
t1
(
Period
smallint
(
4
)
unsigned
zerofill
DEFAULT
'0000'
NOT
NULL
,
Varor_period
smallint
(
4
)
unsigned
DEFAULT
'0'
NOT
NULL
)
ENGINE
=
blackhole
;
INSERT
INTO
t1
VALUES
(
9410
,
9412
);
select
period
from
t1
;
select
*
from
t1
;
select
t1
.*
from
t1
;
#
# Create test table
#
CREATE
TABLE
t2
(
auto
int
NOT
NULL
auto_increment
,
fld1
int
(
6
)
unsigned
zerofill
DEFAULT
'000000'
NOT
NULL
,
companynr
tinyint
(
2
)
unsigned
zerofill
DEFAULT
'00'
NOT
NULL
,
fld3
char
(
30
)
DEFAULT
''
NOT
NULL
,
fld4
char
(
35
)
DEFAULT
''
NOT
NULL
,
fld5
char
(
35
)
DEFAULT
''
NOT
NULL
,
fld6
char
(
4
)
DEFAULT
''
NOT
NULL
,
primary
key
(
auto
)
)
ENGINE
=
blackhole
;
INSERT
INTO
t2
VALUES
(
1192
,
06
8305
,
00
,
'Colombo'
,
'hardware'
,
'colicky'
,
''
);
INSERT
INTO
t2
VALUES
(
1193
,
000000
,
00
,
'nondecreasing'
,
'implant'
,
'thrillingly'
,
''
);
--
enable_query_log
#
# Search with a key
#
select
t2
.
fld3
from
t2
where
companynr
=
58
and
fld3
like
"%imaginable%"
;
select
fld3
from
t2
where
fld3
like
"%cultivation"
;
#
# Search with a key using sorting and limit the same time
#
select
t2
.
fld3
,
companynr
from
t2
where
companynr
=
57
+
1
order
by
fld3
;
select
fld3
,
companynr
from
t2
where
companynr
=
58
order
by
fld3
;
select
fld3
from
t2
order
by
fld3
desc
limit
10
;
select
fld3
from
t2
order
by
fld3
desc
limit
5
;
select
fld3
from
t2
order
by
fld3
desc
limit
5
,
5
;
#
# Search with a key having a constant with each unique key.
# The table is read directly with read-next on fld3
#
select
t2
.
fld3
from
t2
where
fld3
=
'honeysuckle'
;
select
t2
.
fld3
from
t2
where
fld3
LIKE
'honeysuckl_'
;
select
t2
.
fld3
from
t2
where
fld3
LIKE
'hon_ysuckl_'
;
select
t2
.
fld3
from
t2
where
fld3
LIKE
'honeysuckle%'
;
select
t2
.
fld3
from
t2
where
fld3
LIKE
'h%le'
;
select
t2
.
fld3
from
t2
where
fld3
LIKE
'honeysuckle_'
;
select
t2
.
fld3
from
t2
where
fld3
LIKE
'don_t_find_me_please%'
;
#
# Test sorting with a used key (there is no need for sorting)
#
select
t2
.
fld3
from
t2
where
fld3
>=
'honeysuckle'
and
fld3
<=
'honoring'
order
by
fld3
;
select
fld1
,
fld3
from
t2
where
fld3
=
"Colombo"
or
fld3
=
"nondecreasing"
order
by
fld3
;
# Test for fulltext
DROP
TABLE
t1
;
CREATE
TABLE
t1
(
a
VARCHAR
(
200
),
b
TEXT
,
FULLTEXT
(
a
,
b
));
INSERT
INTO
t1
VALUES
(
'MySQL has now support'
,
'for full-text search'
),
(
'Full-text indexes'
,
'are called collections'
),
(
'Only MyISAM tables'
,
'support collections'
),
(
'Function MATCH ... AGAINST()'
,
'is used to do a search'
),
(
'Full-text search in MySQL'
,
'implements vector space model'
);
SHOW
INDEX
FROM
t1
;
# nl search
select
*
from
t1
where
MATCH
(
a
,
b
)
AGAINST
(
"collections"
);
explain
extended
select
*
from
t1
where
MATCH
(
a
,
b
)
AGAINST
(
"collections"
);
select
*
from
t1
where
MATCH
(
a
,
b
)
AGAINST
(
"indexes"
);
select
*
from
t1
where
MATCH
(
a
,
b
)
AGAINST
(
"indexes collections"
);
select
*
from
t1
where
MATCH
(
a
,
b
)
AGAINST
(
"only"
);
drop
table
if
exists
t1
,
t2
;
sql/Makefile.am
View file @
7b81a9fd
...
@@ -62,9 +62,8 @@ noinst_HEADERS = item.h item_func.h item_sum.h item_cmpfunc.h \
...
@@ -62,9 +62,8 @@ noinst_HEADERS = item.h item_func.h item_sum.h item_cmpfunc.h \
sp_head.h sp_pcontext.h sp_rcontext.h sp.h sp_cache.h
\
sp_head.h sp_pcontext.h sp_rcontext.h sp.h sp_cache.h
\
parse_file.h sql_view.h sql_trigger.h
\
parse_file.h sql_view.h sql_trigger.h
\
examples/ha_example.h examples/ha_archive.h
\
examples/ha_example.h examples/ha_archive.h
\
examples/ha_tina.h
\
examples/ha_tina.h
ha_blackhole.h
\
ha_federated.h
ha_federated.h
mysqld_SOURCES
=
sql_lex.cc sql_handler.cc
\
mysqld_SOURCES
=
sql_lex.cc sql_handler.cc
\
item.cc item_sum.cc item_buff.cc item_func.cc
\
item.cc item_sum.cc item_buff.cc item_func.cc
\
item_cmpfunc.cc item_strfunc.cc item_timefunc.cc
\
item_cmpfunc.cc item_strfunc.cc item_timefunc.cc
\
...
@@ -99,7 +98,7 @@ mysqld_SOURCES = sql_lex.cc sql_handler.cc \
...
@@ -99,7 +98,7 @@ mysqld_SOURCES = sql_lex.cc sql_handler.cc \
sp_head.cc sp_pcontext.cc sp_rcontext.cc sp.cc
\
sp_head.cc sp_pcontext.cc sp_rcontext.cc sp.cc
\
sp_cache.cc parse_file.cc sql_trigger.cc
\
sp_cache.cc parse_file.cc sql_trigger.cc
\
examples/ha_example.cc examples/ha_archive.cc
\
examples/ha_example.cc examples/ha_archive.cc
\
examples/ha_tina.cc
\
examples/ha_tina.cc
ha_blackhole.cc
\
ha_federated.cc
ha_federated.cc
gen_lex_hash_SOURCES
=
gen_lex_hash.cc
gen_lex_hash_SOURCES
=
gen_lex_hash.cc
...
...
sql/ha_blackhole.cc
0 → 100644
View file @
7b81a9fd
/* Copyright (C) 2005 MySQL AB
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
#ifdef __GNUC__
#pragma implementation // gcc: Class implementation
#endif
#include <mysql_priv.h>
#ifdef HAVE_BLACKHOLE_DB
#include "ha_blackhole.h"
const
char
**
ha_blackhole
::
bas_ext
()
const
{
static
const
char
*
ext
[]
=
{
NullS
};
return
ext
;
}
int
ha_blackhole
::
open
(
const
char
*
name
,
int
mode
,
uint
test_if_locked
)
{
DBUG_ENTER
(
"ha_blackhole::open"
);
thr_lock_init
(
&
thr_lock
);
thr_lock_data_init
(
&
thr_lock
,
&
lock
,
NULL
);
DBUG_RETURN
(
0
);
}
int
ha_blackhole
::
close
(
void
)
{
DBUG_ENTER
(
"ha_blackhole::close"
);
thr_lock_delete
(
&
thr_lock
);
DBUG_RETURN
(
0
);
}
int
ha_blackhole
::
create
(
const
char
*
name
,
TABLE
*
table_arg
,
HA_CREATE_INFO
*
create_info
)
{
DBUG_ENTER
(
"ha_blackhole::create"
);
DBUG_RETURN
(
0
);
}
const
char
*
ha_blackhole
::
index_type
(
uint
key_number
)
{
DBUG_ENTER
(
"ha_blackhole::index_type"
);
DBUG_RETURN
((
table
->
key_info
[
key_number
].
flags
&
HA_FULLTEXT
)
?
"FULLTEXT"
:
(
table
->
key_info
[
key_number
].
flags
&
HA_SPATIAL
)
?
"SPATIAL"
:
(
table
->
key_info
[
key_number
].
algorithm
==
HA_KEY_ALG_RTREE
)
?
"RTREE"
:
"BTREE"
);
}
int
ha_blackhole
::
write_row
(
byte
*
buf
)
{
DBUG_ENTER
(
"ha_blackhole::write_row"
);
DBUG_RETURN
(
0
);
}
int
ha_blackhole
::
rnd_init
(
bool
scan
)
{
DBUG_ENTER
(
"ha_blackhole::rnd_init"
);
DBUG_RETURN
(
0
);
}
int
ha_blackhole
::
rnd_next
(
byte
*
buf
)
{
DBUG_ENTER
(
"ha_blackhole::rnd_next"
);
DBUG_RETURN
(
HA_ERR_END_OF_FILE
);
}
int
ha_blackhole
::
rnd_pos
(
byte
*
buf
,
byte
*
pos
)
{
DBUG_ENTER
(
"ha_blackhole::rnd_pos"
);
DBUG_ASSERT
(
0
);
DBUG_RETURN
(
0
);
}
void
ha_blackhole
::
position
(
const
byte
*
record
)
{
DBUG_ENTER
(
"ha_blackhole::position"
);
DBUG_ASSERT
(
0
);
DBUG_VOID_RETURN
;
}
void
ha_blackhole
::
info
(
uint
flag
)
{
DBUG_ENTER
(
"ha_blackhole::info"
);
records
=
0
;
deleted
=
0
;
errkey
=
0
;
mean_rec_length
=
0
;
data_file_length
=
0
;
index_file_length
=
0
;
max_data_file_length
=
0
;
delete_length
=
0
;
if
(
flag
&
HA_STATUS_AUTO
)
auto_increment_value
=
1
;
DBUG_VOID_RETURN
;
}
int
ha_blackhole
::
external_lock
(
THD
*
thd
,
int
lock_type
)
{
DBUG_ENTER
(
"ha_blackhole::external_lock"
);
DBUG_RETURN
(
0
);
}
THR_LOCK_DATA
**
ha_blackhole
::
store_lock
(
THD
*
thd
,
THR_LOCK_DATA
**
to
,
enum
thr_lock_type
lock_type
)
{
*
to
++=
&
lock
;
return
to
;
}
int
ha_blackhole
::
index_read
(
byte
*
buf
,
const
byte
*
key
,
uint
key_len
,
enum
ha_rkey_function
find_flag
)
{
DBUG_ENTER
(
"ha_blackhole::index_read"
);
DBUG_RETURN
(
0
);
}
int
ha_blackhole
::
index_read_idx
(
byte
*
buf
,
uint
idx
,
const
byte
*
key
,
uint
key_len
,
enum
ha_rkey_function
find_flag
)
{
DBUG_ENTER
(
"ha_blackhole::index_read_idx"
);
DBUG_RETURN
(
HA_ERR_END_OF_FILE
);
}
int
ha_blackhole
::
index_read_last
(
byte
*
buf
,
const
byte
*
key
,
uint
key_len
)
{
DBUG_ENTER
(
"ha_blackhole::index_read_last"
);
DBUG_RETURN
(
HA_ERR_END_OF_FILE
);
}
int
ha_blackhole
::
index_next
(
byte
*
buf
)
{
DBUG_ENTER
(
"ha_blackhole::index_next"
);
DBUG_RETURN
(
HA_ERR_END_OF_FILE
);
}
int
ha_blackhole
::
index_prev
(
byte
*
buf
)
{
DBUG_ENTER
(
"ha_blackhole::index_prev"
);
DBUG_RETURN
(
HA_ERR_END_OF_FILE
);
}
int
ha_blackhole
::
index_first
(
byte
*
buf
)
{
DBUG_ENTER
(
"ha_blackhole::index_first"
);
DBUG_RETURN
(
HA_ERR_END_OF_FILE
);
}
int
ha_blackhole
::
index_last
(
byte
*
buf
)
{
DBUG_ENTER
(
"ha_blackhole::index_last"
);
DBUG_RETURN
(
HA_ERR_END_OF_FILE
);
}
#endif
/* HAVE_BLACKHOLE_DB */
sql/ha_blackhole.h
0 → 100644
View file @
7b81a9fd
/* Copyright (C) 2005 MySQL AB
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
#ifdef __GNUC__
#pragma interface
/* gcc class implementation */
#endif
/*
Class definition for the blackhole storage engine
"Dumbest named feature ever"
*/
class
ha_blackhole
:
public
handler
{
THR_LOCK_DATA
lock
;
/* MySQL lock */
THR_LOCK
thr_lock
;
public:
ha_blackhole
(
TABLE
*
table
)
:
handler
(
table
)
{
}
~
ha_blackhole
()
{
}
/* The name that will be used for display purposes */
const
char
*
table_type
()
const
{
return
"BLACKHOLE"
;
}
/*
The name of the index type that will be used for display
don't implement this method unless you really have indexes
*/
const
char
*
index_type
(
uint
key_number
);
const
char
**
bas_ext
()
const
;
ulong
table_flags
()
const
{
return
(
HA_NULL_IN_KEY
|
HA_CAN_FULLTEXT
|
HA_CAN_SQL_HANDLER
|
HA_DUPP_POS
|
HA_CAN_INDEX_BLOBS
|
HA_AUTO_PART_KEY
|
HA_FILE_BASED
|
HA_CAN_GEOMETRY
|
HA_READ_RND_SAME
|
HA_CAN_INSERT_DELAYED
);
}
ulong
index_flags
(
uint
inx
,
uint
part
,
bool
all_parts
)
const
{
return
((
table
->
key_info
[
inx
].
algorithm
==
HA_KEY_ALG_FULLTEXT
)
?
0
:
HA_READ_NEXT
|
HA_READ_PREV
|
HA_READ_RANGE
|
HA_READ_ORDER
|
HA_KEYREAD_ONLY
);
}
/* The following defines can be increased if necessary */
#define BLACKHOLE_MAX_KEY 64
/* Max allowed keys */
#define BLACKHOLE_MAX_KEY_SEG 16
/* Max segments for key */
#define BLACKHOLE_MAX_KEY_LENGTH 1000
uint
max_supported_keys
()
const
{
return
BLACKHOLE_MAX_KEY
;
}
uint
max_supported_key_length
()
const
{
return
BLACKHOLE_MAX_KEY_LENGTH
;
}
uint
max_supported_key_part_length
()
const
{
return
BLACKHOLE_MAX_KEY_LENGTH
;
}
int
open
(
const
char
*
name
,
int
mode
,
uint
test_if_locked
);
int
close
(
void
);
int
write_row
(
byte
*
buf
);
int
rnd_init
(
bool
scan
);
int
rnd_next
(
byte
*
buf
);
int
rnd_pos
(
byte
*
buf
,
byte
*
pos
);
int
index_read
(
byte
*
buf
,
const
byte
*
key
,
uint
key_len
,
enum
ha_rkey_function
find_flag
);
int
index_read_idx
(
byte
*
buf
,
uint
idx
,
const
byte
*
key
,
uint
key_len
,
enum
ha_rkey_function
find_flag
);
int
index_read_last
(
byte
*
buf
,
const
byte
*
key
,
uint
key_len
);
int
index_next
(
byte
*
buf
);
int
index_prev
(
byte
*
buf
);
int
index_first
(
byte
*
buf
);
int
index_last
(
byte
*
buf
);
void
position
(
const
byte
*
record
);
void
info
(
uint
flag
);
int
external_lock
(
THD
*
thd
,
int
lock_type
);
int
create
(
const
char
*
name
,
TABLE
*
table_arg
,
HA_CREATE_INFO
*
create_info
);
THR_LOCK_DATA
**
store_lock
(
THD
*
thd
,
THR_LOCK_DATA
**
to
,
enum
thr_lock_type
lock_type
);
};
sql/handler.cc
View file @
7b81a9fd
...
@@ -32,6 +32,9 @@
...
@@ -32,6 +32,9 @@
#ifdef HAVE_BERKELEY_DB
#ifdef HAVE_BERKELEY_DB
#include "ha_berkeley.h"
#include "ha_berkeley.h"
#endif
#endif
#ifdef HAVE_BLACKHOLE_DB
#include "ha_blackhole.h"
#endif
#ifdef HAVE_EXAMPLE_DB
#ifdef HAVE_EXAMPLE_DB
#include "examples/ha_example.h"
#include "examples/ha_example.h"
#endif
#endif
...
@@ -103,6 +106,8 @@ struct show_table_type_st sys_table_types[]=
...
@@ -103,6 +106,8 @@ struct show_table_type_st sys_table_types[]=
"CSV storage engine"
,
DB_TYPE_CSV_DB
},
"CSV storage engine"
,
DB_TYPE_CSV_DB
},
{
"FEDERATED"
,
&
have_federated_db
,
{
"FEDERATED"
,
&
have_federated_db
,
"Federated MySQL storage engine"
,
DB_TYPE_FEDERATED_DB
},
"Federated MySQL storage engine"
,
DB_TYPE_FEDERATED_DB
},
{
"BLACKHOLE"
,
&
have_blackhole_db
,
"Storage engine designed to act as null storage"
,
DB_TYPE_BLACKHOLE_DB
},
{
NullS
,
NULL
,
NullS
,
DB_TYPE_UNKNOWN
}
{
NullS
,
NULL
,
NullS
,
DB_TYPE_UNKNOWN
}
};
};
...
@@ -211,6 +216,10 @@ handler *get_new_handler(TABLE *table, enum db_type db_type)
...
@@ -211,6 +216,10 @@ handler *get_new_handler(TABLE *table, enum db_type db_type)
case
DB_TYPE_ARCHIVE_DB
:
case
DB_TYPE_ARCHIVE_DB
:
return
new
ha_archive
(
table
);
return
new
ha_archive
(
table
);
#endif
#endif
#ifdef HAVE_BLACKHOLE_DB
case
DB_TYPE_BLACKHOLE_DB
:
return
new
ha_blackhole
(
table
);
#endif
#ifdef HAVE_FEDERATED_DB
#ifdef HAVE_FEDERATED_DB
case
DB_TYPE_FEDERATED_DB
:
case
DB_TYPE_FEDERATED_DB
:
return
new
ha_federated
(
table
);
return
new
ha_federated
(
table
);
...
...
sql/handler.h
View file @
7b81a9fd
...
@@ -160,7 +160,7 @@ enum db_type
...
@@ -160,7 +160,7 @@ enum db_type
DB_TYPE_GEMINI
,
DB_TYPE_NDBCLUSTER
,
DB_TYPE_GEMINI
,
DB_TYPE_NDBCLUSTER
,
DB_TYPE_EXAMPLE_DB
,
DB_TYPE_ARCHIVE_DB
,
DB_TYPE_CSV_DB
,
DB_TYPE_EXAMPLE_DB
,
DB_TYPE_ARCHIVE_DB
,
DB_TYPE_CSV_DB
,
DB_TYPE_FEDERATED_DB
,
DB_TYPE_FEDERATED_DB
,
DB_TYPE_BLACKHOLE_DB
,
DB_TYPE_DEFAULT
// Must be last
DB_TYPE_DEFAULT
// Must be last
};
};
...
...
sql/mysql_priv.h
View file @
7b81a9fd
...
@@ -1155,6 +1155,7 @@ extern SHOW_COMP_OPTION have_query_cache, have_berkeley_db, have_innodb;
...
@@ -1155,6 +1155,7 @@ extern SHOW_COMP_OPTION have_query_cache, have_berkeley_db, have_innodb;
extern
SHOW_COMP_OPTION
have_geometry
,
have_rtree_keys
;
extern
SHOW_COMP_OPTION
have_geometry
,
have_rtree_keys
;
extern
SHOW_COMP_OPTION
have_crypt
;
extern
SHOW_COMP_OPTION
have_crypt
;
extern
SHOW_COMP_OPTION
have_compress
;
extern
SHOW_COMP_OPTION
have_compress
;
extern
SHOW_COMP_OPTION
have_blackhole_db
;
#ifndef __WIN__
#ifndef __WIN__
extern
pthread_t
signal_thread
;
extern
pthread_t
signal_thread
;
...
...
sql/mysqld.cc
View file @
7b81a9fd
...
@@ -420,6 +420,7 @@ SHOW_COMP_OPTION have_federated_db;
...
@@ -420,6 +420,7 @@ SHOW_COMP_OPTION have_federated_db;
SHOW_COMP_OPTION
have_raid
,
have_openssl
,
have_symlink
,
have_query_cache
;
SHOW_COMP_OPTION
have_raid
,
have_openssl
,
have_symlink
,
have_query_cache
;
SHOW_COMP_OPTION
have_geometry
,
have_rtree_keys
;
SHOW_COMP_OPTION
have_geometry
,
have_rtree_keys
;
SHOW_COMP_OPTION
have_crypt
,
have_compress
;
SHOW_COMP_OPTION
have_crypt
,
have_compress
;
SHOW_COMP_OPTION
have_blackhole_db
;
/* Thread specific variables */
/* Thread specific variables */
...
@@ -5964,6 +5965,11 @@ static void mysql_init_variables(void)
...
@@ -5964,6 +5965,11 @@ static void mysql_init_variables(void)
#else
#else
have_archive_db
=
SHOW_OPTION_NO
;
have_archive_db
=
SHOW_OPTION_NO
;
#endif
#endif
#ifdef HAVE_BLACKHOLE_DB
have_blackhole_db
=
SHOW_OPTION_YES
;
#else
have_blackhole_db
=
SHOW_OPTION_NO
;
#endif
#ifdef HAVE_FEDERATED_DB
#ifdef HAVE_FEDERATED_DB
have_federated_db
=
SHOW_OPTION_YES
;
have_federated_db
=
SHOW_OPTION_YES
;
#else
#else
...
...
sql/set_var.cc
View file @
7b81a9fd
...
@@ -767,6 +767,7 @@ struct show_var_st init_vars[]= {
...
@@ -767,6 +767,7 @@ struct show_var_st init_vars[]= {
{
sys_group_concat_max_len
.
name
,
(
char
*
)
&
sys_group_concat_max_len
,
SHOW_SYS
},
{
sys_group_concat_max_len
.
name
,
(
char
*
)
&
sys_group_concat_max_len
,
SHOW_SYS
},
{
"have_archive"
,
(
char
*
)
&
have_archive_db
,
SHOW_HAVE
},
{
"have_archive"
,
(
char
*
)
&
have_archive_db
,
SHOW_HAVE
},
{
"have_bdb"
,
(
char
*
)
&
have_berkeley_db
,
SHOW_HAVE
},
{
"have_bdb"
,
(
char
*
)
&
have_berkeley_db
,
SHOW_HAVE
},
{
"have_blackhole_engine"
,
(
char
*
)
&
have_blackhole_db
,
SHOW_HAVE
},
{
"have_compress"
,
(
char
*
)
&
have_compress
,
SHOW_HAVE
},
{
"have_compress"
,
(
char
*
)
&
have_compress
,
SHOW_HAVE
},
{
"have_crypt"
,
(
char
*
)
&
have_crypt
,
SHOW_HAVE
},
{
"have_crypt"
,
(
char
*
)
&
have_crypt
,
SHOW_HAVE
},
{
"have_csv"
,
(
char
*
)
&
have_csv_db
,
SHOW_HAVE
},
{
"have_csv"
,
(
char
*
)
&
have_csv_db
,
SHOW_HAVE
},
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment