Tips for large databases
The advice on this page was for older versions of Gramps so may not work for you. Please update as needed. |
This article's content is incomplete or a placeholder stub. |
Large family tree data files, what to do, and what not to do.
Contents
Loading the file
BSDDB backend
Should work for BSDDB versions of Gramps version 5.1.x and earlier |
Initial import of a large (100,000+) database from either Gramps XML formats or GEDCOM can take a few hours. You will need to adjust the number of allowable locks. For 140,000 people you should use:
- max_locks 300000
- max_objects 300000
The easiest way to do this is to:
- create a new Family Tree
- exit Gramps
- add a
DB_CONFIG
file to the database directory before importing (seegramps -l
output for the directory of a specific family tree.)
Contents of this DB_CONFIG file should be:
#may want to fiddle with cachesize also #set_cachesize 0 200000000 2 set_lk_max_locks 300000 set_lk_max_objects 300000
SQLite backend
Insert following line after the connect statement at line 103 in the gramps/plugins/db/dbapi/sqlite.py file.
self.__connection.execute("PRAGMA cache_size = -50000")
A positive value sets the size in bytes. A negative value sets the size in pages. The size of a typical page is 4096 bytes.
The default value is -2000 which means 2000 pages of 4096 bytes each.
Default view: bookmarks and active person
As there are many people, loading the person view might take some time. See a comparison of performance on large datasets, between different Gramps versions.
You can circumvent this load time by going to the Relationships Category view before opening the family tree. This will open the active person and their family extremely fast, independent of the amount of data you gathered.
You can add bookmarks to common people, or in the branch you are researching. This allows to change person in the relationships view without the need to activate the person in the person view first.
Avoid relationship calculation
Avoid displaying relationships on the status bar. From the Edit > Preferences Display tab change the Status bar option from Relationship to the home person to Active person's name and ID.
Avoid Gramplets
Avoid gramplets which do a lot of database work. The Deep Connections Gramplet seems to be the worst case. Those type of gramplets slow everything down enormously.
Avoid general filters
Filters search all the data looking for the people who satisfy your query. Try to avoid this on large files.
Search letters Fast search can be done by enabling column search (disable Sidebar on View menu), but this will search all letters on words into the column, not only the first letters. |
For a surname search:
- Click on a person in the People Grouped Category view. Now start typing the family name of the person you need. The view will automatically go to the family name as you complete your typing.
- For a more detailed search, use the keyboard shortcut CTRL+F. This will expand all the nodes and allows to search more specifically.
Flat views are faster than Tree views
Using a large family tree database and the People grouped tree view needs to often rebuild the view especially after adding or deleting an object eg: Flat People (list) view is faster than grouped view.