{"id":19133593,"url":"https://github.com/hashload/cqlbr","last_synced_at":"2025-08-23T15:41:45.963Z","repository":{"id":36989509,"uuid":"500913961","full_name":"HashLoad/CQLBr","owner":"HashLoad","description":"CQLBr Framework for Delphi/Lazarus (Isaque Pinheiro)","archived":false,"fork":false,"pushed_at":"2023-10-26T16:06:48.000Z","size":2044,"stargazers_count":19,"open_issues_count":0,"forks_count":9,"subscribers_count":9,"default_branch":"master","last_synced_at":"2024-04-14T00:25:40.369Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"https://www.isaquepinheiro.com.br","language":"Pascal","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/HashLoad.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}},"created_at":"2022-06-07T16:12:29.000Z","updated_at":"2024-02-13T21:31:25.000Z","dependencies_parsed_at":"2023-11-10T11:48:25.420Z","dependency_job_id":null,"html_url":"https://github.com/HashLoad/CQLBr","commit_stats":{"total_commits":75,"total_committers":4,"mean_commits":18.75,"dds":0.09333333333333338,"last_synced_commit":"17be41e769b7f152b23d8be9ac3d7e04e74eb752"},"previous_names":[],"tags_count":11,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/HashLoad%2FCQLBr","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/HashLoad%2FCQLBr/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/HashLoad%2FCQLBr/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/HashLoad%2FCQLBr/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/HashLoad","download_url":"https://codeload.github.com/HashLoad/CQLBr/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":240214566,"owners_count":19766263,"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","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":[],"created_at":"2024-11-09T06:23:01.402Z","updated_at":"2025-02-22T17:41:30.230Z","avatar_url":"https://github.com/HashLoad.png","language":"Pascal","readme":"# CQLBr Library for Delphi/Lazarus\n\nCriteria Query Language is a library that provides writing through an interface, allowing the mapping of object-oriented syntax for performing database query, insert, update, and delete operations.\n\nDuring software development, there is a clear concern about increasing productivity and maintaining compatibility. Regarding databases, in most cases, there is a compatibility break due to the need to write syntax that becomes specific to a particular database. This is where CQLBr comes in. It is designed so that query writing is unique for all databases. When generating a query with CQLBr, it allows you to switch between databases in a system without having to rewrite queries with specific details of the replaced database.\n\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"https://www.isaquepinheiro.com.br\"\u003e\n    \u003cimg src=\"https://github.com/HashLoad/CQLBr/blob/master/Images/cqlbr_framework.png\" width=\"200\" height=\"200\"\u003e\n  \u003c/a\u003e\n\u003c/p\u003e\n\n## 🏛 Delphi versions\nEmbarcadero Delphi XE and above.\n\n## ⚙️ Install\nInstallation using [`boss install`]\n```sh\nboss install cqlbr\n```\n\n## ⚡️ How to use\n\n### SELECT\n\n```Delphi\n  /// \u003csummary\u003e\n  ///   SELECT * FROM CLIENTES WHERE (ID_CLIENTE = 1) AND (ID \u003e= 10) AND (ID \u003c= 20)\n  /// \u003c/summary\u003e\n  TCQL.New(dbnFirebird)\n      .Select\n      .All\n      .From('CLIENTES')\n      .Where('ID_CLIENTE = 1')\n      .\u0026And('ID').GreaterEqThan(10)\n      .\u0026And('ID').LessEqThan(20)\n    .AsString;\n\t\n  \n  /// \u003csummary\u003e\n  ///   SELECT ID_CLIENTE, NOME_CLIENTE, (CASE TIPO_CLIENTE WHEN 0 THEN ''FISICA'' WHEN 1 THEN ''JURIDICA'' ELSE ''PRODUTOR'' END) AS TIPO_PESSOA FROM CLIENTES;\n  /// \u003c/summary\u003e\n  TCQL.New(dbnFirebird)\n      .Select\n      .Column('ID_CLIENTE')\n      .Column('NOME_CLIENTE')\n      .Column('TIPO_CLIENTE')\n        .\u0026Case\n          .When('0').\u0026Then(CQL.Q('FISICA'))\n          .When('1').\u0026Then(CQL.Q('JURIDICA'))\n                    .\u0026Else('''PRODUTOR''')\n        .\u0026End\n        .\u0026As('TIPO_PESSOA')\n        .From('CLIENTES')\n    .AsString);\n\t\n  /// \u003csummary\u003e\n  ///   'SELECT * FROM CLIENTES WHERE (NOME LIKE ''%VALUE%'')';\n  /// \u003c/summary\u003e\n  TCQL.New(dbnFirebird)\n      .Select\n      .All\n      .From('CLIENTES')\n      .Where('NOME').LikeFull('VALUE')\n    .AsString);\n\t\n  /// \u003csummary\u003e\n  ///   'SELECT * FROM CLIENTES WHERE (VALOR IN (1, 2, 3))';\n  /// \u003c/summary\u003e\n  TCQL.New(dbnFirebird)\n      .Select\n      .All\n      .From('CLIENTES')\n      .Where('VALOR').\u0026In([1, 2, 3])\n    .AsString);\n\n  /// \u003csummary\u003e\n  ///   'SELECT * FROM CLIENTES WHERE (NOT EXISTS (SELECT IDCLIENTE FROM PEDIDOS WHERE (PEDIDOS.IDCLIENTE = CLIENTES.IDCLIENTE)))';\n  /// \u003c/summary\u003e\n  TCQL.New(dbnFirebird)\n      .Select\n      .All\n      .From('CLIENTES')\n      .Where.NotExists( TCQL.New(dbnFirebird)\n                            .Select\n                            .Column('IDCLIENTE')\n                            .From('PEDIDOS')\n                            .Where('PEDIDOS.IDCLIENTE').Equal('CLIENTES.IDCLIENTE')\n                        .AsString)\n    .AsString);\n\t\n\t\n```\n\n### INSERT\n\n```Delphi\n  /// \u003csummary\u003e\n  ///   'INSERT INTO CLIENTES (ID_CLIENTE, NOME_CLIENTE) VALUES (''1'', ''MyName'')';\n  /// \u003c/summary\u003e\n  TCQL.New(dbnFirebird)\n      .Insert\n      .Into('CLIENTES')\n      .\u0026Set('ID_CLIENTE', '1')\n      .\u0026Set('NOME_CLIENTE', 'MyName')\n    .AsString);\n```\n\n### UPDATE\n\n```Delphi\n  /// \u003csummary\u003e\n  ///   'UPDATE CLIENTES SET ID_CLIENTE = ''1'', NOME_CLIENTE = ''MyName'' WHERE ID_CLIENTE = 1';\n  /// \u003c/summary\u003e  \n  TCQL.New(dbnFirebird)\n      .Update('CLIENTES')\n      .\u0026Set('ID_CLIENTE', '1')\n      .\u0026Set('NOME_CLIENTE', 'MyName')\n      .Where('ID_CLIENTE = 1')\n    .AsString);\n```\n\n### DELETE\n\n```Delphi\n  /// \u003csummary\u003e\n  ///   'DELETE FROM CLIENTES WHERE ID_CLIENTE = 1';\n  /// \u003c/summary\u003e  \n  TCQL.New(dbnFirebird)\n      .Delete\n      .From('CLIENTES')\n      .Where('ID_CLIENTE = 1')\n    .AsString);\n```\n\n## ✍️ License\n[![License](https://img.shields.io/badge/Licence-LGPL--3.0-blue.svg)](https://opensource.org/licenses/LGPL-3.0)\n\n## ⛏️ Contribution\n\nOur team would love to receive contributions to this open-source project. If you have any ideas or bug fixes, feel free to open an issue or submit a pull request..\n\n[![Issues](https://img.shields.io/badge/Issues-channel-orange)](https://github.com/HashLoad/ormbr/issues)\n\nTo submit a pull request, follow these steps:\n\n1. Fork the project\n2. Create a new branch (`git checkout -b my-new-feature`)\n3. Make your changes and commit (`git commit -am 'Adding new feature'`)\n4. Push the branch (`git push origin my-new-feature`)\n5. Open a pull request.\n\n## 📬 Contact\n[![Telegram](https://img.shields.io/badge/Telegram-channel-blue)](https://t.me/hashload)\n\n## 💲 Donation\n[![Doação](https://img.shields.io/badge/PagSeguro-contribua-green)](https://pag.ae/bglQrWD)\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fhashload%2Fcqlbr","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fhashload%2Fcqlbr","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fhashload%2Fcqlbr/lists"}