BoxLang 🚀 A New JVM Dynamic Language Learn More...
Quick was built out of lessons learned and persistent challenges in developing complex RDBMS applications using built-in Hibernate ORM in CFML.
We can do better.
Quick is an ORM (Object Relational Mapper) written in CFML for CFML. It provides an ActiveRecord implementation for working with your database. With it you can map database tables to components, create relationships between components, query and manipulate data, and persist all your changes to your database.
You need the following configured before using Quick:
quick
in your Application.cfc
BaseGrammar
in config/ColdBox.cfc
See Getting Started for more details.
Quick supports all databases supported by qb.
Here's a "quick" example to whet your appetite.
We'll show the database structure using a migrations file. This isn't required to use quick
, but it is highly recommended.
// 2017_11_10_122835_create_users_table.cfc
component {
function up() {
schema.create( "users", function( table ) {
table.increments( "id" );
table.string( "username" ).unique();
table.string( "email" ).unique();
table.string( "password" );
table.timestamp( "createdDate" );
table.timestamp( "updatedDate" );
} );
}
}
// User
component extends="quick.models.BaseEntity" {
// the name of the table is the pluralized version of the model
// this can be configured on a per-entity basis
}
// handlers/Users.cfc
component {
// /users/:id
function show( event, rc, prc ) {
// this finds the User with an id of 1 and retrieves it
prc.user = getInstance( "User" ).findOrFail( rc.id );
event.setView( "users/show" );
}
}
<!-- views/users/show.cfm -->
<cfoutput>
<h1>Hi, #prc.user.getUsername()#!</h1>
</cfoutput>
Now that you've seen an example, dig in to what you can do with Quick!
To run the tests, first clone this repo and run a box install
.
Quick's test suite runs specifically on MySQL, so you will need a MySQL database to run the tests. If you do not have one, Docker provides an easy way to start one.
docker run -d --name quick -p 3306:3306 -e MYSQL_RANDOM_ROOT_PASSWORD=yes -e MYSQL_DATABASE=quick -e MYSQL_USER=quick -e MYSQL_PASSWORD=quick mysql:5
Finally, copy the .env.example
file to .env
and fill in the values for your database.
Quick is backed by qb. Without qb, there is no Quick.
Quick is inspired heavily by Eloquent in Laravel. Thank you Taylor Otwell and the Laravel community for a great library.
Development of Quick is sponsored by Ortus Solutions. Thank you Ortus Solutions for investing in the future of CFML.
Join us in our Ortus Community and become a valuable member of this project Quick ORM. We are looking forward to hearing from you!
fill
method on the relationship object
(a2da133)newAttributes
and originalAttributes
to the preUpdate
event
(4dd8496)newEntity
function and variable name.
(81aedbb)hasManyThrough
function now returns HasManyDeep
relationships
(1af491a)hasManyDeep
and hasManyDeepBuilder
relationships. (5331b36)hasManyThrough
relationships
(3f3de36)IRelationship
interface
(026d7e0)wirebox:targetId
to support CommandBox (164247d)withCount
and withSum
(e1b17cf)withCount
method to easily add relationship counts to entities (8524ef8)with
(5491ba7)when
closures (96a8f3a)
$
box install quick