sql >> Database teknologi >  >> RDS >> Mysql

Sådan vælger du enheder ved at kalde en lagret procedure med Spring Data

Lad os sige, at dette er din procedure:

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

Du definerer 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 {
    ...
}

Og så kan du kalde din procedure sådan her:

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

Du kan også tjekke dette ved at bruge din EntityManager på denne måde:

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



  1. Overskrider MySQL's TID-værdigrænse på 838:59:59

  2. Hvordan opretter man PHP to kolonne tabel med værdier fra databasen?

  3. Hvordan kan jeg få Redshift/Postgresql LAG-vinduefunktionen til selektivt at ekskludere poster?

  4. Installation og arbejde med MySQL 5 på Windows 7