21
21
#ifndef DRIZZLED_FOREIGN_KEY_H
22
22
#define DRIZZLED_FOREIGN_KEY_H
24
#include "drizzled/memory/sql_alloc.h"
25
#include "drizzled/key.h"
26
#include "drizzled/key_part_spec.h"
27
#include "drizzled/sql_list.h"
28
#include "drizzled/cursor.h" /* for default_key_create_info */
24
#include <drizzled/sql_alloc.h>
25
#include <drizzled/key.h>
26
#include <drizzled/sql_list.h>
36
namespace memory { class Root; }
38
class Foreign_key: public Key
29
typedef struct st_mem_root MEM_ROOT;
31
class Foreign_key: public Key {
33
enum fk_match_opt { FK_MATCH_UNDEF, FK_MATCH_FULL,
34
FK_MATCH_PARTIAL, FK_MATCH_SIMPLE};
35
enum fk_option { FK_OPTION_UNDEF, FK_OPTION_RESTRICT, FK_OPTION_CASCADE,
36
FK_OPTION_SET_NULL, FK_OPTION_NO_ACTION, FK_OPTION_DEFAULT};
58
38
Table_ident *ref_table;
59
39
List<Key_part_spec> ref_columns;
60
40
uint32_t delete_opt, update_opt, match_opt;
61
Foreign_key(const LEX_STRING &name_arg,
62
List<Key_part_spec> &cols,
64
List<Key_part_spec> &ref_cols,
65
uint32_t delete_opt_arg,
66
uint32_t update_opt_arg,
67
uint32_t match_opt_arg) :
68
Key(FOREIGN_KEY, name_arg, &default_key_create_info, 0, cols), ref_table(table),
69
ref_columns(ref_cols),
70
delete_opt(delete_opt_arg),
71
update_opt(update_opt_arg),
41
Foreign_key(const LEX_STRING &name_arg, List<Key_part_spec> &cols,
42
Table_ident *table, List<Key_part_spec> &ref_cols,
43
uint32_t delete_opt_arg, uint32_t update_opt_arg,
44
uint32_t match_opt_arg)
45
:Key(FOREIGN_KEY, name_arg, &default_key_create_info, 0, cols),
46
ref_table(table), ref_columns(ref_cols),
47
delete_opt(delete_opt_arg), update_opt(update_opt_arg),
72
48
match_opt(match_opt_arg)
77
* Constructs an (almost) deep copy of this foreign key. Only those
78
* elements that are known to never change are not copied.
79
* If out of memory, a partial copy is returned and an error is set
82
Foreign_key(const Foreign_key &rhs, memory::Root *mem_root);
86
* Used to make a clone of this object for ALTER/CREATE TABLE
88
* @see comment for Key_part_spec::clone
90
virtual Key *clone(memory::Root *mem_root) const
92
return new (mem_root) Foreign_key(*this, mem_root);
50
Foreign_key(const Foreign_key &rhs, MEM_ROOT *mem_root);
52
Used to make a clone of this object for ALTER/CREATE TABLE
53
@sa comment for Key_part_spec::clone
55
virtual Key *clone(MEM_ROOT *mem_root) const
56
{ return new (mem_root) Foreign_key(*this, mem_root); }
96
57
/* Used to validate foreign key options */
97
bool validate(List<CreateField> &table_fields);
58
bool validate(List<Create_field> &table_fields);
100
} /* namespace drizzled */
102
61
#endif /* DRIZZLED_FOREIGN_KEY_H */