Class: DbMeta::Oracle::TableDataCollection
- Inherits:
-
Object
- Object
- DbMeta::Oracle::TableDataCollection
- Includes:
- Helper
- Defined in:
- lib/db_meta/oracle/types/table_data_collection.rb
Instance Attribute Summary collapse
-
#collection ⇒ Object
readonly
Returns the value of attribute collection.
-
#extract_type ⇒ Object
readonly
Returns the value of attribute extract_type.
-
#name ⇒ Object
readonly
Returns the value of attribute name.
-
#status ⇒ Object
readonly
Returns the value of attribute status.
-
#type ⇒ Object
readonly
Returns the value of attribute type.
Instance Method Summary collapse
- #ddl_drop ⇒ Object
- #extract(args = {}) ⇒ Object
-
#initialize(args = {}) ⇒ TableDataCollection
constructor
A new instance of TableDataCollection.
- #system_object? ⇒ Boolean
Methods included from Helper
#block, #create_folder, #pluralize, #remove_folder, #type_sequence, #write_buffer_to_file
Constructor Details
permalink #initialize(args = {}) ⇒ TableDataCollection
Returns a new instance of TableDataCollection.
8 9 10 11 12 13 14 |
# File 'lib/db_meta/oracle/types/table_data_collection.rb', line 8 def initialize(args = {}) @name = args[:name] @type = args[:type] @status = :valid @extract_type = :default @tables = args[:tables] end |
Instance Attribute Details
permalink #collection ⇒ Object (readonly)
Returns the value of attribute collection.
6 7 8 |
# File 'lib/db_meta/oracle/types/table_data_collection.rb', line 6 def collection @collection end |
permalink #extract_type ⇒ Object (readonly)
Returns the value of attribute extract_type.
6 7 8 |
# File 'lib/db_meta/oracle/types/table_data_collection.rb', line 6 def extract_type @extract_type end |
permalink #name ⇒ Object (readonly)
Returns the value of attribute name.
6 7 8 |
# File 'lib/db_meta/oracle/types/table_data_collection.rb', line 6 def name @name end |
permalink #status ⇒ Object (readonly)
Returns the value of attribute status.
6 7 8 |
# File 'lib/db_meta/oracle/types/table_data_collection.rb', line 6 def status @status end |
permalink #type ⇒ Object (readonly)
Returns the value of attribute type.
6 7 8 |
# File 'lib/db_meta/oracle/types/table_data_collection.rb', line 6 def type @type end |
Instance Method Details
permalink #ddl_drop ⇒ Object
[View source]
51 52 53 |
# File 'lib/db_meta/oracle/types/table_data_collection.rb', line 51 def ddl_drop "-- will automatically be dropped with table object" end |
permalink #extract(args = {}) ⇒ Object
[View source]
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 |
# File 'lib/db_meta/oracle/types/table_data_collection.rb', line 16 def extract(args = {}) buffer = [block(@name)] buffer << "set define off;" buffer << "set sqlblanklines on;" buffer << nil connection = Connection.instance.get @tables.each do |table| Log.info("Extracting data from #{table.name}...") buffer << block(table.name, 40) name_type_map = {} table.columns.each do |column| name_type_map[column.name] = column.type end statement = "select * from #{table.name} #{table.get_core_data_where_clause}" cursor = connection.exec(statement) cursor.fetch_hash do |item| buffer << "insert into #{table.name}(#{item.keys.join(", ")}) values(#{format_values(name_type_map, item)});" end cursor.close buffer << nil end buffer << "commit;" buffer << nil buffer.join("\n") ensure connection.logoff end |
permalink #system_object? ⇒ Boolean
55 56 57 |
# File 'lib/db_meta/oracle/types/table_data_collection.rb', line 55 def system_object? false end |