Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/j256/ormlite-core

Core ORMLite functionality that provides a lite Java ORM in conjunction with ormlite-jdbc or ormlite-android
https://github.com/j256/ormlite-core

database java orm ormlite

Last synced: about 22 hours ago
JSON representation

Core ORMLite functionality that provides a lite Java ORM in conjunction with ormlite-jdbc or ormlite-android

Awesome Lists containing this project

README

        

ORMLite Core
============

This package provides the core functionality for the JDBC and Android packages. Users that are connecting to SQL
databases via JDBC should download the [ormlite-jdbc](https://github.com/j256/ormlite-jdbc) package instead which
includes these core classes. Android users should download the
[ormlite-android](https://github.com/j256/ormlite-android) package instead which also includes these core classes.

* For more information, visit the [ORMLite home page](http://ormlite.com/).
* Online documentation can be found off the home page. Here's the [getting started information](http://ormlite.com/docs/getting-started).
Here are the Javadocs for the code: [![javadoc](https://javadoc.io/badge2/com.j256.ormlite/ormlite-core/javadoc.svg)](https://javadoc.io/doc/com.j256.ormlite/ormlite-core)
* Browse the code on the [git repository](https://github.com/j256/ormlite-core). [![CircleCI](https://circleci.com/gh/j256/ormlite-core.svg?style=svg)](https://circleci.com/gh/j256/ormlite-core) [![CodeCov](https://img.shields.io/codecov/c/github/j256/ormlite-core.svg)](https://codecov.io/github/j256/ormlite-core/)
* Maven packages are published via [![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.j256.ormlite/ormlite-core/badge.svg?style=flat-square)](https://maven-badges.herokuapp.com/maven-central/com.j256.ormlite/ormlite-core/)
* I've published a [number of example programs](http://ormlite.com/docs/examples).

ORMLite is easy to use and provides the following features:

* Setup your classes by simply adding [Java annotations](http://ormlite.com/docs/annotations).
* Powerful abstract [Database Access Object (DAO) classes](http://ormlite.com/docs/dao-setup).
* Flexible [query builder](http://ormlite.com/docs/query-builder) to easily construct simple and complex queries.
* Supports MySQL, Postgres, Microsoft SQL Server, H2, Derby, HSQLDB, and Sqlite and can be extended to additional databases relatively easily.
* Provisional support for DB2, Oracle, ODBC, and Netezza. Contact the author if your database type is not supported.
* Handles "compiled" SQL statements for repetitive query tasks.
* Supports ["foreign" objects](http://ormlite.com/docs/foreign-object) with the class field being the object but an id stored in the database table.
* Basic support for [database transactions](http://ormlite.com/docs/transactions).
* Auto generates SQL to create and drop database tables.
* [Spring configuration support](http://ormlite.com/docs/spring) for DOAs and class configurations.
* Support for [configuring of tables](http://ormlite.com/docs/table-config) and fields without annotations.
* Supports native calls to [Android SQLite database APIs](http://ormlite.com/docs/android).

Enjoy, Gray Watson

# Code Example

The following is a quick code example to give you a taste on how to use the library.

// this uses h2 but you can change it to match your database
String databaseUrl = "jdbc:h2:mem:account";
// create a connection source to our database
ConnectionSource connectionSource = new JdbcConnectionSource(databaseUrl);

// instantiate the DAO to handle Account with String id
Dao accountDao = DaoManager.createDao(connectionSource, Account.class);

// if you need to create the 'accounts' table make this call
TableUtils.createTable(connectionSource, Account.class);

// create an instance of Account
String name = "Jim Smith";
Account account = new Account(name, "_secret");

// persist the account object to the database
accountDao.create(account);

// retrieve the account
Account account2 = accountDao.queryForId(name);
// show its password
System.out.println("Account: " + account2.getPassword());

// close the connection source
connectionSource.close();

# Logging Information

ORMLite has copied in logging code from [SimpleLogging](https://256stuff.com/sources/simplelogging/) which backends to a number of different logging systems and is configurable via code or configuration. For more details see the [logging documentation](https://ormlite.com/docs/logging).

# Maven Configuration

For JDBC usage, you should depend on [![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.j256.ormlite/ormlite-jdbc/badge.svg?style=flat-square)](https://maven-badges.herokuapp.com/maven-central/com.j256.ormlite/ormlite-jdbc/) which includes the core classes.

``` xml

com.j256.ormlite
ormlite-jdbc
6.1

```

For Android usage, you should depend on [![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.j256.ormlite/ormlite-android/badge.svg?style=flat-square)](https://maven-badges.herokuapp.com/maven-central/com.j256.ormlite/ormlite-android/) which includes the core classes.

``` xml

com.j256.ormlite
ormlite-android
6.1

```

# ChangeLog Release Notes

See the [ChangeLog.txt file](src/main/javadoc/doc-files/changelog.txt).