{"id":20699005,"url":"https://github.com/keygenqt/ormlite-extension","last_synced_at":"2026-05-16T13:02:08.538Z","repository":{"id":87143212,"uuid":"312777608","full_name":"keygenqt/ormlite-extension","owner":"keygenqt","description":null,"archived":false,"fork":false,"pushed_at":"2022-10-28T18:07:04.000Z","size":4381,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-03-11T03:42:19.203Z","etag":null,"topics":["android","kotlinpoet","library","ormlite"],"latest_commit_sha":null,"homepage":"","language":"Kotlin","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/keygenqt.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2020-11-14T08:37:14.000Z","updated_at":"2022-10-28T18:06:42.000Z","dependencies_parsed_at":"2023-03-12T20:00:32.469Z","dependency_job_id":null,"html_url":"https://github.com/keygenqt/ormlite-extension","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/keygenqt/ormlite-extension","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/keygenqt%2Formlite-extension","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/keygenqt%2Formlite-extension/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/keygenqt%2Formlite-extension/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/keygenqt%2Formlite-extension/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/keygenqt","download_url":"https://codeload.github.com/keygenqt/ormlite-extension/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/keygenqt%2Formlite-extension/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":268370854,"owners_count":24239779,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-08-02T02:00:12.353Z","response_time":74,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["android","kotlinpoet","library","ormlite"],"created_at":"2024-11-17T00:27:45.015Z","updated_at":"2026-05-16T13:02:03.502Z","avatar_url":"https://github.com/keygenqt.png","language":"Kotlin","funding_links":[],"categories":[],"sub_categories":[],"readme":"\nExtensions OrmLite for Kotlin\n===================\n\nAutomatic work with foreign models and automatic generation extensions for easy work with https://ormlite.com/. \n\nJust **super** KISS work with ormlite)\n\n#### OrmliteBase:\n* Connection (init, close)\n* Auto gen ComponentScanDb\n* Create table if not exist\n* Clear all tables in db\n\n#### Extensions:\n* One-to-one relationships (Model)\n* One-to-many relationships (Collection\\\u003cModel\u003e) \n* Clear tables with relationships\n* Create and update with relationships\n* Model get JSONObject with relationships\n* Other extensions functions\n\n#### For connect:\n\n```groovy\n// Gradle Groovy DSL\nrepositories {\n    maven {\n        url \"https://artifactory.keygenqt.com/artifactory/open-source\"\n    }\n}\ndependencies {\n    kapt 'com.keygenqt.artifactory:gen-ormlite-android:1.0.1'\n}\n```\n\n```kotlin\n// Gradle Kotlin DSL\nrepositories {\n    maven(\"https://artifactory.keygenqt.com/artifactory/open-source\")\n}\ndependencies {\n    kapt(\"com.keygenqt.artifactory:gen-ormlite-android:1.0.1\")\n}\n```\n\n#### Methods extensions:\n\n```kotlin\n// model\nModel().delete()\nModel().createOrUpdate() // Model\nModel().getJSONObject() // JSONObject\n\n// find\nModel.find(\"key\", \"value\") // model\nModel.findOneAND(hashMapOf(\"key\" to \"value\")) // model\nModel.findOneOR(hashMapOf(\"key\" to \"value\")) // model\nModel.findAll(hashMapOf(\"key\" to \"value\")) // list\nModel.findAND(hashMapOf(\"key\" to \"value\")) // list\nModel.findOR(hashMapOf(\"key\" to \"value\")) // list\n\n// Companion\nModel.dao() // Dao\u003cModel, String\u003e\nModel.clearTable()\nModel.clearTableWithForeign()\n```\n\n#### Example:\n\n```kotlin\nclass MainActivity : AppCompatActivity() {\n\n    private lateinit var db: MyOrmliteBase\n\n    override fun onCreate(savedInstanceState: Bundle?) {\n        super.onCreate(savedInstanceState)\n        db = MyOrmliteBase(this, \"name.db\", 1)\n        setContent {\n            MyApplicationTheme {\n                Surface(color = MaterialTheme.colors.background) {\n                    Example()\n                }\n            }\n        }\n    }\n\n    override fun onDestroy() {\n        super.onDestroy()\n        db.close()\n    }\n}\n\n@Composable\nfun Example() {\n    Column(\n        modifier = Modifier.padding(16.dp)\n    ) {\n\n        // clear all tables in db\n        OrmliteBase.clearDb()\n\n        // clear table only model\n        ModelUser.clearTable()\n\n        // clear table model with foreign models\n        ModelUser.clearTableWithForeign()\n\n        val id = UUID.randomUUID().toString()\n\n        // example create model with foreign\n        ModelUser(\n            id,\n            \"First name\",\n            \"Last name\",\n            ModelUserAddress(\"Volgodonsk\", \"Russia\"),\n            arrayListOf(\n                ModelUserParent(\"First name mather\", \"Last name mather\"),\n                ModelUserParent(\"First name father\", \"Last name father\"),\n            )\n        ).createOrUpdate()\n\n        // find model\n        ModelUser.find(\"id\", id)?.let {\n            Text(\"It's exist - $id\")\n            Log.d(\"TAG\", it.getJSONObject().toString())\n        } ?: run {\n            Text(\"It's not exist - $id\")\n        }\n\n        // find model with AND\n        ModelUser.findOneAND(hashMapOf(\"fname\" to \"First name\", \"lname\" to \"Last name\"))?.let {\n            Text(\"Find model 'findOneAND'\")\n            Log.d(\"TAG\", it.getJSONObject().toString())\n        }\n\n        // find models list with AND\n        ModelUser.findAND(hashMapOf(\"fname\" to \"First name\", \"lname\" to \"Last name\")).firstOrNull()\n            ?.let {\n                Text(\"Find model 'findAND'\")\n                Log.d(\"TAG\", it.getJSONObject().toString())\n            }\n\n        // find model with OR\n        ModelUser.findOneOR(hashMapOf(\"fname\" to \"First name\", \"lname\" to \"Last name\"))?.let {\n            Text(\"Find model 'findOneOR'\")\n            Log.d(\"TAG\", it.getJSONObject().toString())\n        }\n\n        // find models list with OR\n        ModelUser.findOR(hashMapOf(\"fname\" to \"First name\", \"lname\" to \"Last name\")).firstOrNull()?.let {\n            Text(\"Find model 'findOR'\")\n            Log.d(\"TAG\", it.getJSONObject().toString())\n        }\n\n        // find models list\n        ModelUser.findAll().firstOrNull()?.let {\n            Text(\"Find model 'findAll'\")\n            Log.d(\"TAG\", it.getJSONObject().toString())\n        }\n\n        // update model\n        ModelUser.find(\"id\", id)?.let {\n            it.fname = \"First name UPDATE\"\n            it.address.city = \"City UPDATE\"\n            it.parents?.firstOrNull()?.let { p -\u003e\n                p.fname = \"First name mather UPDATE\"\n            }\n            it.createOrUpdate()\n        }\n\n        // show update\n        ModelUser.find(\"id\", id)?.let {\n            Text(\"Find after Update model\")\n            Log.d(\"TAG\", it.getJSONObject().toString())\n        }\n    }\n}\n```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkeygenqt%2Formlite-extension","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fkeygenqt%2Formlite-extension","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkeygenqt%2Formlite-extension/lists"}