sql >> Databáze >  >> RDS >> Mysql

Jak vybrat entity voláním uložené procedury pomocí Spring Data

Řekněme, že toto je váš postup:

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

Definujete @NamedStoredProcedureQuery :

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

A pak můžete svou proceduru nazvat takto:

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

Můžete to také zkontrolovat pomocí vašeho EntityManager takto:

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



  1. Získejte aktuální přihlašovací ID na SQL Server (T-SQL)

  2. MySQL vybere název sloupce a hodnotu jako pole

  3. Jak přejmenovat tabulku v SQL

  4. MySQL JSON Document Store metoda pro vkládání dat do uzlu 3 úrovně hluboko