Ir al contenido principal

Hibernate - Queries

Load an entity

There are two forms to get an entity with the methods load() or get().

public Category getCategory(Long catId) throws DataAccessException {
    return (Category) this.getSessionFactory().getCurrentSession()
.load(Category.class, catId); }

public Category getCategory(Long catId) throws DataAccessException {
return (Category) this.getSessionFactory().getCurrentSession()

.get(Category.class, catId); }








The difference are:



  • load()


    • Throws an exception if there isn't any row.

    • Has performane benefits.


  • get()


    • Return null if there isn't any row.







HibernateTemplate - Using Parameters with findByNamedParam






In case of use only one parameter, you need the query, parameter name and the value.





public List<ArtEntity> getArtworkInCategory(Long catId)
throws DataAccessException {
return this.getHibernateTemplate().findByNamedParam(
"select art from Category cat " +
"join cat.artEntities art " +
"where cat.id = :catId ",
"catId", catId
);
}
In case of many parameters, you need the query, array with the parameters and the array with corresponding values
public Person authenticatePerson(String username, String password)
throws DataAccessException, AuthenticationException {

List<Person> validUsers = this.getHibernateTemplate().findByNamedParam(
"select people from Person people where" +
"people.username = :username " +
"and people.password = :password",
new String[] {"username", "password"},
new String[] {username, password }
);

if (validUsers == null || validUsers.size() <= 0) {
throw new AuthenticationException("No users found");
} else {
return validUsers.get(0);
}
}

Hibernate Core APIs - Using Parameters

public Person authenticatePerson(String username, String password)
throws DataAccessException, AuthenticationException {

Person validUser =
(Person) this.getSessionFactory().getCurrentSession().createQuery(
"select people from Person people where" +
"people.username = :username " +
"and people.password = :password")
.setString("username", username)
.setString("password", password)
.uniqueResult()
);

if (validUser == null) {
throw new AuthenticationException("No users found");
} else {
return validUser;
}
}

Comentarios

Entradas populares de este blog

C# Using tabs

To use tabs in C# use the TabContainer element from AjaxControlToolkit Include AjaxControlToolkit  Include in the Web.config file, inside the tag <system.web> the following code  <pages>       <controls>         <add tagPrefix="ajaxCTK" namespace="AjaxControlToolkit" assembly="AjaxControlToolkit"/>       </controls>     </pages>   Include TabContainer element First  include TabContainer element that is the section where all the tabs will be displayed. <ajaxCTK:TabContainer ID="TabContainerUpdate" runat="server"                 Height="800"                 CssClass="ajax__tab_style"> </ajaxCTK:TabContainer> Second per each tab include the following code corresponding to each ...

Rails - Basic Steps III

pValidations Validations are a type of ActiveRecord Validations are defined in our models Implement Validations Go to   root_app/app/models Open files  *.rb for each model Mandatory field validates_presence_of   :field Ex:   validates_presence_of    :title Classes The basic syntax is class MyClass        @global_variable                def my_method              @method_variable        end end Create an instance myInstance = MyClass.new Invoke a mehod mc.my_method class() method returns the type of the object In Ruby, last character of method define the behavior If ends with a question -> return a boolean value If ends with an exclamation -> change the state of the object Getter / Setter method def global_variable       return @global_variable end ...

Python create package

Create a root folder Create a sub-folder "example_pkg" that contains the funtionallity packaging_tutorial/ example_pkg/ __init__.py In the root folder create the following structure  packaging_tutorial/ example_pkg/ __init__.py tests/ setup.py LICENSE README.md in the setup.py contains the configuration of the packages your package is found by find_packages() import setuptools with open ( "README.md" , "r" ) as fh : long_description = fh . read () setuptools . setup ( name = "example-pkg-YOUR-USERNAME-HERE" , # Replace with your own username version = "0.0.1" , author = "Example Author" , author_email = "author@example.com" , description = "A small example package" , long_description = long_description , long_description_content_type = "text/markdown" , url = "https://github.com/pypa/sam...