
Security News
Crates.io Users Targeted by Phishing Emails
The Rust Security Response WG is warning of phishing emails from rustfoundation.dev targeting crates.io users.
Import the data at a high speed to the table from a text file, using the MySQL LOAD DATA INFILE
statement.
This gem is dependent on mysql2.
By using mysql2, as well as plugin of ActiveRecord, it is possible to use in pure Ruby script.
Add to your Gemfile:
gem 'load_data_infile2'
And bundle.
Database configuration:
db_config = {
host: 'localhost'
database: 'ldi_test'
username: 'root'
}
Create client:
ldi_client = LoadDataInfile2::Client.new(db_config)
Import from CSV file:
ldi_client.import('/path/to/data.csv')
Default options are CSV format:
module LoadDataInfile2
class << self
def default_import_options
@default_import_options ||= {
fields_terminated_by: ',', # CSV
fields_optionally_enclosed_by: '"', # standard format of CSV
fields_escaped_by: '"', # standard format of CSV
lines_terminated_by: "\\n",
ignore_lines: 0
}
end
end
end
If you are using TSV format:
opts = {
fileds_terminated_by: "\\t",
fields_optionally_enclosed_by: "",
fields_escaped_by: "\\"
}
ldi_client = LoadDataInfile2::Client.new(db_config, opts)
ldi_client.import('/path/to/data.tsv')
If you use LOCAL
option:
opts = { local_infile: true }
ldi_client = LoadDataInfile2::Client.new(db_config, opts)
ldi_client.import('/path/to/data.csv')
# => Execute "LOAD DATA LOCAL INFILE '/path/to/data.csv' INTO TABLE `ldi_test`.`data`;"
Support all options of LOAD DATA INFILE statement on MySQL 5.7 .
see: http://dev.mysql.com/doc/refman/5.7/en/load-data.html
For examples:
opts = { local_infile: true }
sql_opts = { table: 'special_users', ignore_lines: 1 }
ldi_client = LoadDataInfile2::Client.new(db_config, opts)
ldi_client.import('/path/to/users.csv', sql_opts)
MySQL | LoadDataInfile2 |
---|---|
LOW_PRIORITY | low_priority_or_concurrent: :low_priority |
CONCURRENT | low_priority_or_concurrent: :concurrent |
LOCAL | local_infile: true |
REPLACE | replace_or_ignore: :replace |
IGNORE | replace_or_ignore: :ignore |
tbl_name | table: 'special_table_name' |
PARTITION | partition: 'p0' / ['p0', 'p1', ...] |
CHARCTER SET | charset: 'utf8' |
FIELDS TERMINATED BY | fields_terminated_by: ',' |
FIELDS ENCLOSED BY | fields_enclosed_by: '"' |
FIELDS OPTIONALLY ENCLOSED BY | fields_optionally_enclosed_by: '"' |
FIELDS ESCAPED BY | fields_escaped_by: '"' |
LINES STARTING BY | lines_starting_by: '***' |
LINES TERMINATED BY | lines_terminated_by: '\n' |
IGNORE LINES | ignore_lines: 1 |
col_name_or_user_var | columns: ['col1', 'col2', '@var3', ...] |
SET col_name = expr | set: { col1: "'specific value'", col2: '@var', col3: 'NOW()' } |
Subclass of ActiveRecord is added .load_data_infile
.
For example, in the case of User model, you can call the class method named load_data_infile
from the User model.
User.load_data_infile('/path/to/data.csv')
If you want to pass options to the initialization of LoadDataInfile2::ActiveRecord
, you can use the accessor of class variable named .default_load_data_infile_options
.
User.default_load_data_infile_options = { ignore_lines: 1 }
User.load_data_infile('/path/to/data.csv')
Bug reports and pull requests are welcome on GitHub at https://github.com/nalabjp/load_data_infile2.
MIT License
The gem is available as open source under the terms of the MIT License.
FAQs
Unknown package
We found that load_data_infile2 demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
The Rust Security Response WG is warning of phishing emails from rustfoundation.dev targeting crates.io users.
Product
Socket now lets you customize pull request alert headers, helping security teams share clear guidance right in PRs to speed reviews and reduce back-and-forth.
Product
Socket's Rust support is moving to Beta: all users can scan Cargo projects and generate SBOMs, including Cargo.toml-only crates, with Rust-aware supply chain checks.