ホームページ Java &#&チュートリアル Spring Data Repositories で生の SQL クエリを実行するにはどうすればよいですか?

Spring Data Repositories で生の SQL クエリを実行するにはどうすればよいですか?

Nov 02, 2024 am 02:57 AM

How Can I Execute Raw SQL Queries with Spring Data Repositories?

Spring Data Repositories を使用した生の SQL クエリの実行

Spring Data Repositories の @Query アノテーションは通常、エンティティベースのクエリを使用しますが、 NativeQuery フラグを使用して生の SQL クエリを実行できます。このフラグを true に設定すると、リポジトリ メソッド内で直接 SQL を実行できるようになります。

<code class="java">@Query(value = "SELECT * FROM table_name", nativeQuery = true)
List&lt;Object[]&gt; executeNativeQuery();</code>
ログイン後にコピー

この例では、nativeQuery フラグが @Query アノテーションで true に設定されています。これにより、クエリでネイティブ SQL を実行し、結果を Object[][] 配列として返すことができます。

また、Spring Data JPA は名前付きネイティブ クエリもサポートしています。このアプローチにより、リソース ファイル (*.sql ファイルなど) でネイティブ クエリを定義し、名前付きクエリ アノテーションを使用してそれらを参照できるようになります。例:

<code class="java">@NamedNativeQuery(name = "findByName", query = "SELECT * FROM table_name WHERE name = :name")
interface UserRepository {
    @Query("findByName")
    List&lt;User&gt; findByName(@Param("name") String name);
}</code>
ログイン後にコピー

この例では、findByName メソッドは名前付きネイティブ クエリを使用して、名前に基づいてユーザーを検索します。名前付きクエリは、*.sql ファイルで次のように定義されます。

<code class="sql">SELECT * FROM table_name WHERE name = :name;</code>
ログイン後にコピー

nativeQuery フラグまたは名前付きネイティブ クエリを利用することで、生の SQL クエリを Spring Data Repositories に組み込むことが可能になり、柔軟な実行が可能になります。さまざまなデータベース操作。

以上がSpring Data Repositories で生の SQL クエリを実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Javaのクラスロードメカニズムは、さまざまなクラスローダーやその委任モデルを含むどのように機能しますか? Javaのクラスロードメカニズムは、さまざまなクラスローダーやその委任モデルを含むどのように機能しますか? Mar 17, 2025 pm 05:35 PM

Javaのクラスロードメカニズムは、さまざまなクラスローダーやその委任モデルを含むどのように機能しますか?

2025年のトップ4 JavaScriptフレームワーク:React、Angular、Vue、Svelte 2025年のトップ4 JavaScriptフレームワーク:React、Angular、Vue、Svelte Mar 07, 2025 pm 06:09 PM

2025年のトップ4 JavaScriptフレームワーク:React、Angular、Vue、Svelte

高度なJavaプロジェクト管理、自動化の構築、依存関係の解像度にMavenまたはGradleを使用するにはどうすればよいですか? 高度なJavaプロジェクト管理、自動化の構築、依存関係の解像度にMavenまたはGradleを使用するにはどうすればよいですか? Mar 17, 2025 pm 05:46 PM

高度なJavaプロジェクト管理、自動化の構築、依存関係の解像度にMavenまたはGradleを使用するにはどうすればよいですか?

キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPA(Java Persistence API)を使用するにはどうすればよいですか? キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPA(Java Persistence API)を使用するにはどうすればよいですか? Mar 17, 2025 pm 05:43 PM

キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPA(Java Persistence API)を使用するにはどうすればよいですか?

node.js 20:キーパフォーマンスが向上し、新機能 node.js 20:キーパフォーマンスが向上し、新機能 Mar 07, 2025 pm 06:12 PM

node.js 20:キーパフォーマンスが向上し、新機能

Iceberg:データレイクテーブルの未来 Iceberg:データレイクテーブルの未来 Mar 07, 2025 pm 06:31 PM

Iceberg:データレイクテーブルの未来

Spring Boot Snakeyaml 2.0 CVE-2022-1471問題修正 Spring Boot Snakeyaml 2.0 CVE-2022-1471問題修正 Mar 07, 2025 pm 05:52 PM

Spring Boot Snakeyaml 2.0 CVE-2022-1471問題修正

Javaで機能的なプログラミング技術を実装するにはどうすればよいですか? Javaで機能的なプログラミング技術を実装するにはどうすればよいですか? Mar 11, 2025 pm 05:51 PM

Javaで機能的なプログラミング技術を実装するにはどうすればよいですか?

See all articles