ホームページ ウェブフロントエンド jsチュートリアル 3 javascript orm you no no no no no no no no no not

3 javascript orm you no no no no no no no no no not

Feb 19, 2025 am 08:56 AM

3 JavaScript ORMs You Might Not Know

コアポイント

    この記事では、アプリケーションの複雑なデータを管理するために使用できる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の選択は、プロジェクトの特定の要件、データベースの複雑さ、および必要な機能に基づいている必要があります。
JavaScriptには、単なるブラウザスクリプトやインタラクティブなWebサイト以上のものがあります。ほぼどこでも使用できます:

    ブラウザサイド: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

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'
});
ログイン後にコピー
ログイン後にコピー
ご覧のとおり、knexインスタンスをパラメーターとして渡して、本棚オブジェクトを作成します。その後、上記の例のユーザーテーブルに使用されるユーザーモデルと同様に、モデルのextend()メソッドを使用してアプリケーションにモデルを作成できます。本棚は、アプリケーション全体で使用する唯一の本棚のインスタンスであることを忘れないでください。そのため、シングルトンにラップしたり、別のファイルに入れたり、必要に応じて紹介するなど、アプリケーションのどこでも利用できるようにする方が良いでしょう。本棚を使用すると、1対1の、1対10の関係と多くの関係を持つことができます。私たちの場合、それは次のとおりです

チェックアウトしたい場合は、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
ログイン後にコピー
このコードスニペットは、TODO_DBという名前のデータベースと、指定された列(プライマリキー、タスク、締め切り、および完了したID)の名前のデータベースを作成する方法を示しています。この時点で、すべての未完成のタスクのリストを取得するには、コードは次のとおりです。

上記のコードは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'
});
ログイン後にコピー
ログイン後にコピー
これらの簡単なクエリに加えて、ラブフィールドは参加など、より複雑なクエリを処理できます。 2つのテーブルプロジェクトと開発者(それぞれテーブルプロジェクトと開発者を参照)に参照があり、特定の開発者のすべてのプロジェクトを見たい場合は、次のように書きます。

したがって、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 サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

javascriptの分解:それが何をするのか、なぜそれが重要なのか javascriptの分解:それが何をするのか、なぜそれが重要なのか Apr 09, 2025 am 12:07 AM

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

JavaScriptの進化:現在の傾向と将来の見通し JavaScriptの進化:現在の傾向と将来の見通し Apr 10, 2025 am 09:33 AM

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

JavaScriptエンジン:実装の比較 JavaScriptエンジン:実装の比較 Apr 13, 2025 am 12:05 AM

さまざまなJavaScriptエンジンは、各エンジンの実装原則と最適化戦略が異なるため、JavaScriptコードを解析および実行するときに異なる効果をもたらします。 1。語彙分析:ソースコードを語彙ユニットに変換します。 2。文法分析:抽象的な構文ツリーを生成します。 3。最適化とコンパイル:JITコンパイラを介してマシンコードを生成します。 4。実行:マシンコードを実行します。 V8エンジンはインスタントコンピレーションと非表示クラスを通じて最適化され、Spidermonkeyはタイプ推論システムを使用して、同じコードで異なるパフォーマンスパフォーマンスをもたらします。

JavaScript:Web言語の汎用性の調査 JavaScript:Web言語の汎用性の調査 Apr 11, 2025 am 12:01 AM

JavaScriptは、現代のWeb開発のコア言語であり、その多様性と柔軟性に広く使用されています。 1)フロントエンド開発:DOM操作と最新のフレームワーク(React、Vue.JS、Angularなど)を通じて、動的なWebページとシングルページアプリケーションを構築します。 2)サーバー側の開発:node.jsは、非ブロッキングI/Oモデルを使用して、高い並行性とリアルタイムアプリケーションを処理します。 3)モバイルおよびデスクトップアプリケーション開発:クロスプラットフォーム開発は、反応および電子を通じて実現され、開発効率を向上させます。

Python vs. JavaScript:学習曲線と使いやすさ Python vs. JavaScript:学習曲線と使いやすさ Apr 16, 2025 am 12:12 AM

Pythonは、スムーズな学習曲線と簡潔な構文を備えた初心者により適しています。 JavaScriptは、急な学習曲線と柔軟な構文を備えたフロントエンド開発に適しています。 1。Python構文は直感的で、データサイエンスやバックエンド開発に適しています。 2。JavaScriptは柔軟で、フロントエンドおよびサーバー側のプログラミングで広く使用されています。

next.jsを使用してマルチテナントSaaSアプリケーションを構築する方法(フロントエンド統合) next.jsを使用してマルチテナントSaaSアプリケーションを構築する方法(フロントエンド統合) Apr 11, 2025 am 08:22 AM

この記事では、許可によって保護されたバックエンドとのフロントエンド統合を示し、next.jsを使用して機能的なedtech SaaSアプリケーションを構築します。 FrontEndはユーザーのアクセス許可を取得してUIの可視性を制御し、APIリクエストがロールベースに付着することを保証します

C/CからJavaScriptへ:すべてがどのように機能するか C/CからJavaScriptへ:すべてがどのように機能するか Apr 14, 2025 am 12:05 AM

C/CからJavaScriptへのシフトには、動的なタイピング、ゴミ収集、非同期プログラミングへの適応が必要です。 1)C/Cは、手動メモリ管理を必要とする静的に型付けられた言語であり、JavaScriptは動的に型付けされ、ごみ収集が自動的に処理されます。 2)C/Cはマシンコードにコンパイルする必要がありますが、JavaScriptは解釈言語です。 3)JavaScriptは、閉鎖、プロトタイプチェーン、約束などの概念を導入します。これにより、柔軟性と非同期プログラミング機能が向上します。

next.jsを使用してマルチテナントSaaSアプリケーションを構築する(バックエンド統合) next.jsを使用してマルチテナントSaaSアプリケーションを構築する(バックエンド統合) Apr 11, 2025 am 08:23 AM

私はあなたの日常的な技術ツールを使用して機能的なマルチテナントSaaSアプリケーション(EDTECHアプリ)を作成しましたが、あなたは同じことをすることができます。 まず、マルチテナントSaaSアプリケーションとは何ですか? マルチテナントSaaSアプリケーションを使用すると、Singの複数の顧客にサービスを提供できます

See all articles