data:image/s3,"s3://crabby-images/acd87/acd8709ab45adfba6bce27372cf2c56ff61bf73b" alt="Tests"
Squeel 🔄
Squeel is a powerful SQL-to-MongoDB query translator that enables you to write MongoDB queries using familiar SQL syntax. It bridges the gap between SQL and MongoDB's query language, making it easier for developers familiar with SQL to work with MongoDB.
✨ Features
- 🔄 Translates SQL SELECT queries to MongoDB operations
- 🚀 Supports complex queries including:
- JOIN operations with
$lookup
- Aggregate functions (COUNT, SUM, AVG, MIN, MAX)
- WHERE clauses with multiple conditions
- GROUP BY and HAVING clauses
- ORDER BY for sorting
- LIMIT and OFFSET for pagination
- 🔧 Handles UUID fields automatically (converts to Binary for uppercase collections)
- 📦 Supports subqueries and nested field queries
- ⚡ Maintains MongoDB's native performance characteristics
📥 Installation
go get github.com/fanfactory/data/squeel
🚀 Quick Start
import "github.com/fanfactory/data/squeel"
sql := "SELECT name, age FROM users WHERE age > 21 ORDER BY name DESC LIMIT 10"
statement := squeel.NewStatement(sql)
query := squeel.NewQuery()
query, err := statement.Build(query)
if err != nil {
log.Fatal(err)
}
📖 Usage Examples
Basic Queries
SELECT * FROM users
SELECT * FROM User WHERE _id = '695FF995-5DC4-4FBE-B80C-2621360D578F'
SELECT first_name FROM user_profile WHERE _id = '695FF995-5DC4-4FBE-B80C-2621360D578F'
SELECT * FROM fanchecks LIMIT 10 OFFSET 2
Advanced Queries
SELECT u.name, p.city
FROM users u
JOIN profiles p ON u.id = p.user_id
WHERE u.age > 25
SELECT department, AVG(salary) as avg_salary
FROM employees
WHERE hire_date >= '2020-01-01'
GROUP BY department
HAVING AVG(salary) > 50000
SELECT * FROM products
WHERE name LIKE '%phone%'
AND (category = 'Electronics' OR category = 'Accessories')
AND price BETWEEN 100 AND 500
SELECT * FROM questions WHERE theme.nl = 'Some Theme'
🔧 Query Object Structure
Squeel translates SQL queries into a Query
struct that can be used with the MongoDB driver:
type Query struct {
Context context.Context
Comment string
Operation string
Collection string
Filter bson.D
Projection bson.D
Sort bson.D
Limit *int64
Offset *int64
Pipeline mongo.Pipeline
Payload bson.D
}
Query Operations
find
: Regular SELECT queriesfindone
: SELECT with LIMIT 1aggregate
: Complex queries with JOIN, GROUP BY, or aggregation functionscount
: COUNT queriesdistinct
: SELECT DISTINCT queries
Automatic UUID Handling
Squeel automatically handles UUID fields differently based on collection naming:
- Uppercase collections (e.g.,
User
): UUIDs are converted to MongoDB Binary type - Lowercase collections (e.g.,
users
): UUIDs remain as strings
🤝 Contributing
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
📄 License
This project is licensed under the MIT License - see the LICENSE file for details.
🙏 Acknowledgments
Special thanks to all contributors who have helped make Squeel better!