sql >> Databasteknik >  >> RDS >> Mysql

Hur man väljer entiteter genom att anropa en lagrad procedur med Spring Data

Låt oss säga att detta är din procedur:

CREATE OR REPLACE PROCEDURE get_users(data out SYS_REFCURSOR)
AS
BEGIN
OPEN data FOR SELECT * FROM USERS;
END;

Du definierar en @NamedStoredProcedureQuery :

@NamedStoredProcedureQuery(
    name="getUsers", 
    procedureName="get_users", 
    resultClass=User.class, parameters={
        @StoredProcedureParameter(queryParameter="data", name="data", direction=Direction.OUT_CURSOR)
    }
)
@Entity
public class User {
    ...
}

Och sedan kan du kalla din procedur så här:

public UserRepository extends JpaRepository<User, Long>{
    @Procedure('User.getUsers')
    List<User> getUsers();
}

Du kan också kontrollera detta med din EntityManager så här:

Query query = entitymanager.createNamedQuery("getUsers");
List users = query.getResultList();



  1. Skapa schema om det inte finns genom att använda spring Jpa med viloläge

  2. Välj distinkta aviseringar och förbered ett tydligare meddelande

  3. Oracle:Connect By Loop i användardata

  4. [A]MySql.Data.MySqlClient.MySqlConnection kan inte castas till [B]MySql.Data.MySqlClient.MySqlConnection