Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xmas7/sterlingnosql
This is the project for Sterling, and object-oriented database Jeremy Likness created to meet the growing demand for queryable, persistent storage in Silverlight and Windows Phone apps in the early two-thousand tens.
https://github.com/xmas7/sterlingnosql
database db dotnet nosql oop sterling
Last synced: 27 days ago
JSON representation
This is the project for Sterling, and object-oriented database Jeremy Likness created to meet the growing demand for queryable, persistent storage in Silverlight and Windows Phone apps in the early two-thousand tens.
- Host: GitHub
- URL: https://github.com/xmas7/sterlingnosql
- Owner: xmas7
- License: ms-pl
- Created: 2022-09-30T16:44:32.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-06-19T07:54:57.000Z (over 1 year ago)
- Last Synced: 2024-12-05T15:13:38.952Z (27 days ago)
- Topics: database, db, dotnet, nosql, oop, sterling
- Language: C#
- Homepage:
- Size: 7.27 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Support: docs/Support for Composite Keys.md
Awesome Lists containing this project
README
# Sterling NoSQL Object-Oriented Database
This is the project for Sterling, and object-oriented database Jeremy Likness created to meet the growing demand for queryable, persistent storage in Silverlight and Windows Phone apps in the early two-thousand tens.
![Sterling Database](./Sterling-Final-Small.png)
This project was migrated from CodePlex. You can read the legacy documentation [here](./docs/Home.md).
If you want to browse the code, the "heart" or "brains" of Sterling are contained in [SerializationHelper.cs](./src/SterlingSln/Wintellect.Sterling/Serialization/SerializationHelper.cs). The rest of the codebase can be inferred from there.
At the time, Sterling was designed to be an unobtrusive solution for taking existing C# classes and persisting them without having to modify the classes themselves. A common use case for this was "tombstoning" Windows phone apps, which referred to saving the View Model that contained the app state when the app is swapped to the background so it can be restored later.
A few features of Sterling:
* It could serialize almost any class "as is"
* For special cases you could define your own serializers
* It supported "byte interceptors" to modify the raw streams (i.e. for compression or encryption, etc.)
* It supported multiple databases
* You could define triggers to be called as data was saved (for validation) or loaded (for computed fields, etc.)
* Lambda expressions defined indexes (i.e. index on name: entity => entity.name)
* The storage was decoupled from the database engine, so you could write your own persistence or leverage the built-in engines including a server side storage engine that used the file system, an isolated storage mechanism for phones and an in-memory default engine for cacheSterling was later ported to [support WinRT apps](https://github.com/Wintellect/SterlingDB).
The original [online user guide](https://sites.google.com/site/sterlingdatabase/) still exists.
For nostalgia, you can still browse [old Twitter conversations about Sterling](https://twitter.com/search?q=%23sterlingdb).