freqtrade_origin/docs/sql_cheatsheet.md
2019-03-08 22:15:03 +01:00

2.5 KiB

SQL Helper

This page constains some help if you want to edit your sqlite db.

Install sqlite3

Ubuntu/Debian installation

sudo apt-get install sqlite3

Open the DB

sqlite3
.open <filepath>

Table structure

List tables

.tables

Display table structure

.schema <table_name>

Trade table structure

CREATE TABLE trades (
	id INTEGER NOT NULL,
	exchange VARCHAR NOT NULL,
	pair VARCHAR NOT NULL,
	is_open BOOLEAN NOT NULL,
	fee_open FLOAT NOT NULL,
	fee_close FLOAT NOT NULL,
	open_rate FLOAT,
	open_rate_requested FLOAT,
	close_rate FLOAT,
	close_rate_requested FLOAT,
	close_profit FLOAT,
	stake_amount FLOAT NOT NULL,
	amount FLOAT,
	open_date DATETIME NOT NULL,
	close_date DATETIME,
	open_order_id VARCHAR,
	stop_loss FLOAT,
	initial_stop_loss FLOAT,
	stoploss_order_id VARCHAR,
	stoploss_last_update DATETIME,
	max_rate FLOAT,
	sell_reason VARCHAR,
	strategy VARCHAR,
	ticker_interval INTEGER,
	PRIMARY KEY (id),
	CHECK (is_open IN (0, 1))
);

Get all trades in the table

SELECT * FROM trades;

Fix trade still open after a manual sell on the exchange

!!! Warning: Manually selling on the exchange should not be done by default, since the bot does not detect this and will try to sell anyway. /foresell should accomplish the same thing.

!!! Note: This should not be necessary after /forcesell, as forcesell orders are closed automatically by the bot on the next iteration.

UPDATE trades
SET is_open=0, close_date=<close_date>, close_rate=<close_rate>, close_profit=close_rate/open_rate-1, sell_reason=<sell_reason>  
WHERE id=<trade_ID_to_update>;
Example
UPDATE trades
SET is_open=0, close_date='2017-12-20 03:08:45.103418', close_rate=0.19638016, close_profit=0.0496, sell_reason='force_sell'  
WHERE id=31;

Insert manually a new trade

INSERT INTO trades (exchange, pair, is_open, fee_open, fee_close, open_rate, stake_amount, amount, open_date)
VALUES ('bittrex', 'ETH/BTC', 1, 0.0025, 0.0025, <open_rate>, <stake_amount>, <amount>, '<datetime>')
Example:
INSERT INTO trades (exchange, pair, is_open, fee_open, fee_close, open_rate, stake_amount, amount, open_date)
VALUES ('bittrex', 'ETH/BTC', 1, 0.0025, 0.0025, 0.00258580, 0.002, 0.7715262081, '2017-11-28 12:44:24.000000')

Fix wrong fees in the table

If your DB was created before PR#200 was merged (before 12/23/17).

UPDATE trades SET fee=0.0025 WHERE fee=0.005;