Migrating To Db Expert guidance for migrating Logseq graphs from Markdown (MD) format to the new Database (DB) format. Auto-invokes when users ask about MD to DB migration, converting graphs, import options, data transformation, or compatibility between Logseq versions. Covers migration strategies, common issues, and best practices.
0 スター
2026/03/02
Migrating to Logseq DB
When to Use This Skill
This skill auto-invokes when:
User asks about migrating from Logseq MD to DB version
Converting markdown graphs to database format
Import/export between Logseq versions
Questions about what transfers during migration
Namespace handling during migration
Tag-to-class conversion decisions
Property type inference during import
User mentions "migrate", "convert", "MD to DB", "markdown to database"
You are an expert in migrating Logseq graphs from MD (Markdown) format to DB (Database) format.
Migration Overview
Why Migrate?
Feature MD Version DB Version Storage Markdown files SQLite database
クイックインストール
Migrating To Db npx skills add slurpyb/registry
スター 0
更新日 2026/03/02
職業 Tags Page references Classes with properties
Properties Text strings Typed values
Queries Limited Full Datalog
Sync File-based Real-time (subscription)
Performance File I/O dependent Optimized queries
Current Status (2024-2025) Important : Logseq DB is still in alpha . Consider:
Data loss risk exists
Some features not yet available (whiteboards)
Plugin compatibility varies
Requires subscription for sync
Pre-Migration Checklist Before migrating, assess your graph:
1. Backup Everything # Create timestamped backup
cp -r ~/logseq/my-graph ~/logseq/my-graph-backup-$(date +%Y%m%d)
# Or compress
tar -czvf my-graph-backup.tar.gz ~/logseq/my-graph
2. Audit Current Structure
3. Identify Migration Decisions MD Pattern DB Options Decision Needed #tagClass or page ref Which tags become classes? [[page]]Node reference Keep as reference property:: valueTyped property What type? namespace/pageSeparate page or hierarchy Flatten or nest?
Migration Process
Step 1: Export from MD Version
Open your MD graph in Logseq
Go to Settings → Export
Choose Export to EDN (for full data)
Save the export file
Step 2: Prepare Import Settings When importing to DB, you'll choose:
Convert to classes : Tags become proper classes with inherited properties
Keep as references : Tags remain simple page links
Flatten : a/b/c → single page "a/b/c"
Hierarchical : Creates page hierarchy
Infer types : Logseq guesses types (number, date, etc.)
All as text : Everything stays as strings
Step 3: Create New DB Graph
Create new DB-based graph in Logseq
Use Import feature
Select your exported data
Configure migration options
Review and confirm
Step 4: Post-Migration Validation ;; Check page count matches
[:find (count ?p)
:where [?p :block/tags ?t]
[?t :db/ident :logseq.class/Page]]
;; Check for orphaned blocks
[:find (pull ?b [:block/title])
:where [?b :block/title _]
(not [?b :block/page _])
(not [?b :block/tags ?t]
[?t :db/ident :logseq.class/Page])]
;; Verify properties migrated
[:find ?prop-name (count ?b)
:where [?b ?prop _]
[?p :db/ident ?prop]
[?p :block/title ?prop-name]
[(clojure.string/starts-with? (str ?prop) ":user.property")]]
Common Migration Issues
Issue 1: Lost Property Types Symptom : Numbers/dates stored as strings
Solution : Manually update property types
;; In DB, update property type
{:db/ident :user.property/rating
:logseq.property/type :number} ; was :default
Issue 2: Tag/Class Confusion Symptom : Tags didn't become proper classes
Solution : Convert pages to classes
Open the tag page
Add #Tag to make it a class
Define properties on the class
Issue 3: Broken References Symptom : [[page]] links not working
Cause : Page names changed during migration
Solution : Use find/replace or query to identify broken refs
[:find ?ref-text
:where
[?b :block/title ?title]
[(re-find #"\[\[.*?\]\]" ?title) ?ref-text]
(not [_ :block/title ?ref-text])]
Issue 4: Namespace Flattening Symptom : project/tasks and project/notes merged
Solution : Pre-migration, rename pages to avoid conflicts
Issue 5: Query Compatibility Symptom : Old queries don't work
Reason : Different attribute names
MD Attribute DB Attribute :block/content:block/title:block/name:block/title:page/tags:block/tags
Migration Strategies
Strategy 1: Big Bang Migration
Migrate entire graph at once
Best for: Small graphs, simple structure
Risk: All-or-nothing
Strategy 2: Parallel Operation
Keep MD graph active
Create DB graph for new content
Gradually move old content
Best for: Large graphs, active use
Strategy 3: Selective Migration
Export specific pages/areas
Import into new DB graph
Best for: Messy graphs needing cleanup
Best Practices
Before Migration
Clean up your graph
Remove unused pages
Standardize property names
Fix broken links
Document your structure
List all tags and their purposes
Document property meanings
Map namespaces
Plan your classes
Which tags become classes?
What properties do they need?
Define inheritance hierarchy
During Migration
Start small - Test with a subset
Compare counts - Pages, blocks, properties
Check critical pages - Most important content first
Verify queries - Update and test all queries
After Migration
Don't delete MD graph - Keep as backup
Monitor for issues - Note problems for feedback
Update workflows - Adapt to new features
Explore new capabilities - Classes, typed properties
Feature Comparison
Available in DB Version
✅ Typed properties (number, date, checkbox)
✅ Class inheritance
✅ Property schemas
✅ Full Datalog queries
✅ Real-time collaboration (Pro)
✅ Library view
Not Yet Available (Alpha)
⏳ Whiteboards
⏳ Some plugins
⏳ Full export options
⏳ Advanced templates
Different Behavior
📝 Tags = Classes (more powerful but different)
📝 Sync requires subscription
📝 File access limited (SQLite, not .md)
Resources 02
When to Use This Skill
Migrating To Db | Skills Pool