Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jhawthorn/fast_sqlite
Speeds up tests using sqlite :zap:
https://github.com/jhawthorn/fast_sqlite
ruby sqlite
Last synced: 13 days ago
JSON representation
Speeds up tests using sqlite :zap:
- Host: GitHub
- URL: https://github.com/jhawthorn/fast_sqlite
- Owner: jhawthorn
- License: mit
- Created: 2014-03-05T12:09:22.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2024-10-22T20:07:03.000Z (3 months ago)
- Last Synced: 2024-12-24T00:52:37.150Z (15 days ago)
- Topics: ruby, sqlite
- Language: Ruby
- Homepage:
- Size: 5.86 KB
- Stars: 10
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# FastSqlite
Makes sqlite faster... but at what cost?
(The cost is data integrity :bomb:)
## K, what's it actually do?
It modifies following two sqlite settings on newly opened connections
PRAGMA synchronous = 0;
> If the application running SQLite crashes, the data will be safe, but the database might become corrupted if the operating system crashes or the computer loses power before that data has been written to the disk surface. On the other hand, some operations are as much as 50 or more times faster with synchronous OFF.
\- [SQLite docs](http://www.sqlite.org/pragma.html#pragma_synchronous)
PRAGMA journal_mode = MEMORY;
> The MEMORY journaling mode stores the rollback journal in volatile RAM. This saves disk I/O but at the expense of database safety and integrity. If the application using SQLite crashes in the middle of a transaction when the MEMORY journaling mode is set, then the database file will very likely go corrupt.
\- [SQLite docs](http://www.sqlite.org/pragma.html#pragma_journal_mode)
These settings are dangerous. Making this only suitable for test environments.
## Installation
Add this line to your application's Gemfile:
gem 'fast_sqlite', group: :test
And then execute:
$ bundle
## Contributing
1. Fork it ( http://github.com/jhawthorn/fast_sqlite/fork )
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create new Pull Request