3 javascript orm you no no no no no no no no no not
コアポイント
-
この記事では、アプリケーションの複雑なデータを管理するために使用できる3つのJavaScript ormを紹介します:bookshelf.js、execelize、およびlovefield。 bookshelf.jsおよびexecelizeはnode.js用に設計されており、postgreSQL、MySQL、MariadB、SQLite3、およびMSSQLでうまく動作します。 Lovefieldは、Googleが開発したIndexEdDB上に構築されたWebアプリケーションリレーショナルデータベースです。
- bookshelf.jsおよびSequelizeにより、開発者はテーブル間で1対1の、1対多で多くの関係を作成できます。また、トランザクション、関係、読み取り、複製もサポートしています。ラブフィールドは生のSQLクエリをサポートしていませんが、SQLの構文を模倣し、酸トランザクション、制限とスキップ、パラメーター化されたクエリなどをサポートします。
- SQLの知識は開発者にとって重要ですが、JavaScript ORMは複雑なデータとデータベースの相互作用を処理することにより、作業を簡素化できます。 ORMの選択は、プロジェクトの特定の要件、データベースの複雑さ、および必要な機能に基づいている必要があります。
- ブラウザサイド:ECMAScriptとDOM APIに限定する必要はありません。 CoffeescriptとDartは、コードをより速くより良く書くのに役立つ純粋なJavaScript言語にコンパイルされます。
- サーバー側:node.jsの数とその多くのフレームワークの数が増加しており、フロントエンド開発者がフルスタック開発者になるのに役立ちます。
- モバイルアプリ:CordovaやIonicやNativeScriptなどのフレームワークを使用して、JavaやSwift/Objective-Cなどの他の言語を学習せずにモバイルアプリケーションをより速く構築できます。これらのフレームワークを使用すると、モバイルプラットフォーム間でソースコードを共有することもできます。
- IoT:SitePointは、Patrick Catanzaritiの記事をいくつか公開しています。これは、この点で非常に役立ちます。
- 開発アプリケーションの複雑さが増加するにつれて、データベースサーバー(PostgreSQLなど)、モバイルデバイス用の埋め込みSQLite、または内部にあるかどうかにかかわらず、データベースに保存されているすべてのデータを処理するためのツールが必要です。ブラウザ。これがORMがしていることです。 Javaコミュニティには冬眠があり、PHP開発者はDoctrine ORMを使用でき、JavaScriptコミュニティには独自のORMもあります。この記事では、次のアプリケーションで複雑なデータを処理するのに役立つJavaScript ormsについて説明します。
bookshelf.jsは、postgresql、mysql、mariadb、およびsqlite3でうまく機能するように設計されたnode.js ormです。 Knex SQLクエリビルダーの上に構築され、モデルやコレクション、同様の命名規則など、BackBone.jsのパターンに従います。バックボーンを使用したことがある場合は、非常に迅速に本棚に慣れることがあります。本棚をインストールするには、Knexとデータベースドライバーをインストールする必要があります。
# 获取 knex $ npm install knex --save # 获取 bookshelf $ npm install bookshelf --save # 获取其中一个数据库驱动程序 $ npm install pg $ npm install mysql $ npm install mariasql $ npm install sqlite3
インストールが完了したら(パッケージファイルに追加されるように、-saveフラグを渡すようにしてください)、node.jsアプリケーションで使用できます。
var knexInstance = require('knex')({ client: 'mysql', // 或您正在使用的数据库 connection: { host : '127.0.0.1', user : 'scott', password : 'tiger', // Scott 的猫的名字 database : 'db_name', charset : 'utf8' } }); // 通过传递 Knex 实例来初始化 Bookshelf var bookshelf = require('bookshelf')(knexInstance); var User = bookshelf.Model.extend({ tableName: 'users' });
チェックアウトしたい場合は、Githubで本棚を見つけることができます。
var User = bookshelf.Model.extend({ tableName: 'users', posts: function() { return this.hasMany(Post); } }); var Post = bookshelf.Model.extend({ tableName: 'posts', user: function() { return this.belongsTo(User); } });
の後遺症 Sequelizeは、node.jsとio.jsの別のORMです(結局マージされます)。 PostgreSQL、MySQL、MariadB、SQLite、MSSQLをサポートし、強力なトランザクションサポート、関係、読み取り、レプリカ機能を備えています。次のコマンドを実行してインストールできます。
次の例に示すように使用できます。
# 安装 Sequelize $ npm install --save sequelize # 安装数据库驱动程序 $ npm install --save pg pg-hstore # 对于 mysql 和 mariadb 方言 $ npm install --save mysql $ npm install --save sqlite3 # MSSQL $ npm install --save tedious
Apecelize.String上記のSQLのVarcharと一致します。他のデータ型は、integer for integer and sackelize.blob for blob(またはpostgresのbytea)のintegerです。ここで完全なリストを読むことができます。 Sequelizeを使用すると、テーブル間の関係を作成できます。たとえば、プロジェクトと呼ばれるモデルと開発者と呼ばれる別のモデルがあり、複数の開発者をプロジェクトに割り当てたい場合は、これを行うことができます。
var Sequelize = require('sequelize'); var sequelize = new Sequelize('database', 'username', 'password', { host: 'localhost', dialect: 'mysql'|'mariadb'|'sqlite'|'postgres'|'mssql', // 使用其中一个 pool: { max: 5, min: 0, idle: 10000 }, // 仅限 SQLite storage: 'path/to/database.sqlite' }); // 或者您可以简单地使用连接 uri var sequelize = new Sequelize('postgres://user:pass@example.com:5432/dbname');
これにより、必要なフィールドが各モデルに追加されることが保証されます(この場合、開発者モデルのProject_id)。または、Sequelize APIの恩恵を受けることができないと感じた場合は、RAW SQLクエリを実行できます。 SequelizeはGitHubでも入手できます。
var User = sequelize.define('user', { firstName: { type: Sequelize.STRING, field: 'first_name' // `first_name` 列与 User.firstName 匹配 }, lastName: { type: Sequelize.STRING } }, { freezeTableName: true // 模型 tableName (`user`) 将与模型名称相同 });
lovefield
Project.hasMany(Developer, {as: 'devs'})
ラブフィールドは本当のormではありません。実際、これは、Googleによって開発され、JavaScriptで完全に書かれたIndexEdDB上に構築されたWebアプリケーションのリレーショナルデータベースです。生のSQLクエリはサポートしていませんが、SQL構文を模倣しようとするAPIが付属しています。 bower:
を使用してインストールできますまたはnpm:
HTMLファイルに追加した後、フロントエンドのリレーショナルデータベースとして使用を開始できます。データベースとテーブルを作成するのは簡単です:
$ bower install lovefield --save
上記のコードはSQLに非常に似ています。同じクエリは次のとおりです。
# 获取 knex $ npm install knex --save # 获取 bookshelf $ npm install bookshelf --save # 获取其中一个数据库驱动程序 $ npm install pg $ npm install mysql $ npm install mariasql $ npm install sqlite3
次のようにソートすることもできます
var knexInstance = require('knex')({ client: 'mysql', // 或您正在使用的数据库 connection: { host : '127.0.0.1', user : 'scott', password : 'tiger', // Scott 的猫的名字 database : 'db_name', charset : 'utf8' } }); // 通过传递 Knex 实例来初始化 Bookshelf var bookshelf = require('bookshelf')(knexInstance); var User = bookshelf.Model.extend({ tableName: 'users' });
したがって、LovefieldはindexedDBの上のSQLレイヤーとして機能することがわかります。また、酸トランザクション(原子性、一貫性、分離、持続性)、制限とスキップ(ページング時に役立つ)、パラメーター化されたクエリなどをサポートします。他の骨のように、GithubからLovefieldをダウンロードできます。
var User = bookshelf.Model.extend({ tableName: 'users', posts: function() { return this.hasMany(Post); } }); var Post = bookshelf.Model.extend({ tableName: 'posts', user: function() { return this.belongsTo(User); } });
すべての開発者はSQLの知識を持っている必要がありますが、SQLクエリを書くことは退屈で、特に非常に多くのORMがいます。彼らがあなたの仕事を楽にするとき、最初にそれらを使用してみませんか?この記事では、これまでにリリースされた最も重要なORMのいくつかを取り上げました。各ORMに提供された例のおかげで、どのORMを使用するか、どのORMがニーズに合うかを意識的に決定できるようになりました。あなたはどうですか?どのJavaScript ormを使用していますか?以下の選択についてコメントしてください。
(そのコンテンツが記事のトピックに弱く関連しており、長すぎるため、後続のFAQセクションは省略されています。これは擬似オリジナル効果に影響します。以上が3 javascript orm you no no no no no no no no no notの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











フロントエンドのサーマルペーパーチケット印刷のためのよくある質問とソリューションフロントエンド開発におけるチケット印刷は、一般的な要件です。しかし、多くの開発者が実装しています...

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

スキルや業界のニーズに応じて、PythonおよびJavaScript開発者には絶対的な給与はありません。 1. Pythonは、データサイエンスと機械学習でさらに支払われる場合があります。 2。JavaScriptは、フロントエンドとフルスタックの開発に大きな需要があり、その給与もかなりです。 3。影響要因には、経験、地理的位置、会社の規模、特定のスキルが含まれます。

この記事の視差スクロールと要素のアニメーション効果の実現に関する議論では、Shiseidoの公式ウェブサイト(https://www.shisido.co.co.jp/sb/wonderland/)と同様の達成方法について説明します。

JavaScriptを学ぶことは難しくありませんが、挑戦的です。 1)変数、データ型、関数などの基本概念を理解します。2)非同期プログラミングをマスターし、イベントループを通じて実装します。 3)DOM操作を使用し、非同期リクエストを処理することを約束します。 4)一般的な間違いを避け、デバッグテクニックを使用します。 5)パフォーマンスを最適化し、ベストプラクティスに従ってください。

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

同じIDを持つ配列要素をJavaScriptの1つのオブジェクトにマージする方法は?データを処理するとき、私たちはしばしば同じIDを持つ必要性に遭遇します...

Zustand非同期操作のデータの更新問題。 Zustand State Management Libraryを使用する場合、非同期操作を不当にするデータ更新の問題に遭遇することがよくあります。 �...
