거래 로봇을 무료로 다운로드 하는 법을 시청해보세요
당사를 Telegram에서 찾아주십시오!
당사 팬 페이지에 가입하십시오
스크립트가 흥미로우신가요?
그렇다면 링크 to it -
하셔서 다른 이들이 평가할 수 있도록 해보세요
스크립트가 마음에 드시나요? MetaTrader 5 터미널에서 시도해보십시오
라이브러리

MySQL library for MQL4 with proper memory management - MetaTrader 4용 라이브러리

조회수:
12096
평가:
(22)
게시됨:
2015.08.25 10:41
업데이트됨:
2016.11.22 07:32
mql4-mysql.mqh (10.56 KB) 조회
libmySQL.zip (938.39 KB)
MQL5 프리랜스 이 코드를 기반으로 한 로봇이나 지표가 필요하신가요? 프리랜스로 주문하세요 프리랜스로 이동

Original library file mql4-mysql.mqh is located here: https://www.mql5.com/en/code/11114 . Give respect to the original authors for the work done (originally created by Russell, then modified by vedroid and lukins / Sergey) and read description of the original code.

The original mql4-mysql.mqh library had a serious problem with memory management. Problems were reported by several users (you can read about it here: https://www.mql5.com/en/forum/28941).

Since I wanted to use library as part of my projects, I simply couldn't afford memory build up which would result in crash of the system. After examination of the code I managed to trace the problem to the FetchArray function, which allows user to read and save data from database. Memory wasn't properly released or allocated, so I made several changes to the code that should prevent memory leak.

Test of the improved library was made and the memory consumption remained stable. Test lasted for several hours and included several thousand connections/read of data with minimal increase of memory usage (less then 10 MB), which is probably the result of MetaTrader 4 itself and indicators running (not a clean install of MetaTrader 4 terminal). From my previous test, the original library couldn't handle more then a few reads from database and only worked for several minutes before collapsing. Test was done with EA, which requested data on every tick.

IMPORTANT: Read original description of library for example!

int     dbConnectId = 0;

Should be declared as local variable, not as a global. If you use library with EA or indicator, then local declaration is necessary. This is done so that with every iteration, the variable memory address is different (automatically allocated by MetaTrader 4) and released after the cycle.

You should also open connections for every specific task. Maintaining connection open for several different requests isn't advised. Example: I want to read several rows from database and save it into array, I declare this procedure in a function. When function is called, connection is established and when data is read, connection is closed and after that function returns XX data. Connection is opened for minimum amount of time.

Always remember to close connection with deinit_MySQL, if you don't, connections will build up and with time you will reach MAX number of connections allowed by server running your database. Server will crash.

Also proper transaction management should be implemented, so that two or more connections don't interfere with each other. Can cause read data violation, this will stop your EA from working.

Apache server with MySQL DB for those who needed it (free software):

If you want simple DB, server and DB management tool (it's free and friendly for users): https://www.apachefriends.org/index.html

Read this for how to set protection for DB: http://robsnotebook.com/xampp-builtin-security

Test it, please give feedback. That's the only way problems can be fixed.

Info:

I could write a forum post with detailed examples on how to use the library and what is needed to use it.

This is quite a substantial subject, so I will only write it if there's need for it. Post a request if you want me to write a user manual.

Flag and Pennant patterns Flag and Pennant patterns

This indicator shows Flag and Pennant patterns.

Support Resistance - Tools Support Resistance - Tools

Easily create horizontal lines by 1 key stroke, choose the color of the resistance line and the support line, the indicator automatically changes the color when a line is crossed, you can be alerted when a line is crossed. You can see the history of support and resistance of the line.

COrdersManager class COrdersManager class

Simple way to control your orders.

Histogram Blanket Histogram Blanket

This new representation helps to see charts in a new different way.