Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/LainPavot/DBModelR
An ORM written in R.
https://github.com/LainPavot/DBModelR
Last synced: 17 days ago
JSON representation
An ORM written in R.
- Host: GitHub
- URL: https://github.com/LainPavot/DBModelR
- Owner: LainPavot
- License: agpl-3.0
- Created: 2020-06-09T09:37:53.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-08-01T11:02:20.000Z (over 1 year ago)
- Last Synced: 2023-08-02T15:29:08.724Z (over 1 year ago)
- Language: R
- Size: 707 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.Rmd
- License: LICENSE
Awesome Lists containing this project
- jimsghstars - LainPavot/DBModelR - An ORM written in R. (R)
README
---
output:
github_document:
html_preview: false
---DBModelR
======
The DBModelR is an ORM package (Object-Relationnal Mapping).
This ORM aims to abstract the database layer in R programs, and provide
simple objects to create, load, update and remove data fom the database
transparently, using only R Objects.It's built atop of RSQLite and R-DBI, but may include other DBMS like
PostGreSQL, or MySQL.You can install the latest released version from CRAN with:
install.packages("DBModelR")
Or install the latest development version from GitHub with:
devtools::install_github("LainPavot/DBModelR")
Basic usage
======```{r}
library("RSQLite")
library("DBModelR")models <- list(
person=ModelDefinition(
table="person",
fields=list(
name="TEXT",
family_name="TEXT"
), many=list("adress")
## One person possibly has multiple adress. Or none...
## "many" fields defines the creation of a linkage table
## (many_to_many or one_to_many).
## "one" fields defines a fk field enforced by a foreign key
## restriction (one_to_one)
## "many" fields mustn't be duplicated. So, "adress" must not
## reference the "person" table.
),
adress=ModelDefinition(
table="adress",
fields=list(
number="INTEGER",
street="TEXT"
)
)
)DB_PATH <- "./people.sqlite"
if (file.exists(DB_PATH)) {
file.remove(DB_PATH)
}
orm <- ORM(connection_params=list(DB_PATH), model_definitions=models)## like this, we'll see the requests generated by the orm
print(orm$create_database())
## the tables has been generated, fks and their restrictions has been
## defined and linked table has been created if necessary## we've created a person who's name is Alice Smith.
## Alice has been saved into the database.
alice <- orm$person(name="Alice", family_name="smith")$save()## Alice has been successfully added to and loaded from the database.
print(orm$person()$load_by(name="Alice"))## The id is 1, because it's the first person to be inserted into the
## "person" table.
## The orm has generated an "INSERT" query.
print(alice$get_id())## He's a boy, so he's changed his name to "Bob". Suits him better.
## Fields must always be setted with "model$set_field_name(value)".
## otherwise the orm will not see the modifications, and will not save
## them in the database.
bob <- alice$set_name("bob")$save()## still 1. Because the orm did not add new database entry.
## The orm has generated an "UPDATE" query.
print(bob$get_id())## prints an empty list()
## no adress has been assigned to him for the moment.
print(bob$get_adress())## let's give him a home
bob$add_adress(
## the orm sanitizes the user's inputs and prevent sql injections.
orm$adress(number=42, street="Second street ; -- drop table person")
)
## The orm detects that the adress object assigned to bob is not saved
## yet in the database.
## So, the orm will register the adress, and then create a link between
## bob and the adress through a linkage table.
bob$save()## now Bob is happy because he has an adress
## prints: list( ...) etc.
print(adress <- bob$get_adress())## the street name is still somewat strange...
## let's make it less strange
bob$get_adress(
## we select the adress with a strange name...
street="Second street ; -- drop table person"## we set a more... usual name. And we save it (the adress).
)[[1]]$set_street("Second street")$save()
print(bob$get_adress())## never forget to disconnect when your're finished!
orm$disconnect()## not to forget, there's a little trick:
## this call orm$connect()
## and at the end of the block, it calls orm$disconnect()
## so you never foget to disconnect from the database.
orm <- ORM(connection_params=list(DB_PATH), model_definitions=models, connect=FALSE)
orm$with_connection({
bob <- orm$person()$load_by(name="bob")$first()
bob$add_adress(
## he's has a second residence
orm$adress(number=2, street="the squirel's path")
)$save()
print(bob$get_adress())## finily he decided to live in his second house, and sold the
## first one.
print(bob$get_adress(street="Second street"))
bob$remove_adress(bob$get_adress(street="Second street")$first())
bob$save()
print(bob$get_adress())})
## now, you're disconnected from the database.
file.remove(DB_PATH)
```Context
======This package has been initialized in the ANR RHU project ChoPIn
(Cholesterol Personnelized Innovations), at the "plateforme
d'exploration du metabolisme" (Metabolism exploration
plateform - PFEM), at INRAE of Clermont-Theix in France.The ORM was a part of the "XSeeker" tool that I was coding, and I
decided to make a more compleet tool. So on my free time, I created
this package, largly inspired from the original code.# Contributor Code of Conduct
As contributors and maintainers of this project, we pledge to respect all people who contribute through reporting issues, posting feature requests, updating documentation, submitting pull requests or patches, and other activities.
We are committed to making participation in this project a harassment-free experience for everyone, regardless of level of experience, gender, gender identity and expression, sexual orientation, disability, personal appearance, body size, ethnicity, age, or religion.
Examples of unacceptable behavior by participants include the use of sexual language or imagery, derogatory comments or personal attacks, trolling, public or private harassment, insults, or other unprofessional conduct.
Project maintainers have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct. Project maintainers who do not follow the Code of Conduct may be removed from the project team.
Instances of abusive, harassing, or otherwise unacceptable behavior may be reported by opening an issue or contacting one or more of the project maintainers.
This Code of Conduct is adapted from the [Contributor Covenant](http:contributor-covenant.org), version 1.0.0, available at [http://contributor-covenant.org/version/1/0/0/](http://contributor-covenant.org/version/1/0/0/).