【hibernate】03-Query 对数据库增删改查

 Session 对象的 save() add() delete() 方法  

里面都是一个参数对象 默认只能根据id 操作     

 get(User.name,id)里面两个参数 

这都没有什么技术难度

下面说说 query 对数据库增删改查

以 实体类User为例

 

一、 用query  查找对象(hql语句)
String hql =  "from User as user where user.name=?" ;
 Query query = session.createQuery(hql);
 query.setString(0, name);
 List<User> list =query.list
如果确定查询结果只有一个值 用 
User user =(User)query.uniqueResult();接收

分页查询
query.setFirstResult(firstResults);
query.setMaxResults(maxResults);
return query.list();

二 删除对象
tx = session.beginTransaction();
String hql =   "delete User where n ame=:name"  ;
Query query = session.createQuery(hql);
query.setString(   "name" , name);
query.executeUpdate();  这条语句是必须的不然不会更新
tx.commit();

三更新对象
tx = session.beginTransaction();
String hql =   "update User set name=:name where id=:id" ;
Query query = session.createQuery(hql);
query.setString(   "name" , name);
query.setInteger(   "id" , id);
query.executeUpdate();
tx.commit();

四、增加对象
tx = session.beginTransaction();
String hql =  "insert into User(name)values (:name)" ;
Query query = session.createSQLQuery(hql);
query.setString(  "name" , name);
query.executeUpdate();
tx.commit();

这种方法一般不用  是sql 语句  一般直接用 session.save()

 

By  变坏的好人

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hibernate是一个Java持久化框架,用于将Java对象映射到关系型数据库中,以便进行增删改查操作。 以下是使用Hibernate进行增删改查的步骤: 1. 创建Hibernate配置文件,指定数据库连接信息、实体类映射信息等。 2. 创建实体类,使用注解或XML文件将实体类映射到数据库表中。 3. 编写DAO(Data Access Object)层代码,用于操作数据库。DAO层可以使用Hibernate提供的API,也可以使用HQL(Hibernate Query Language)语句。 4. 在应用程序中调用DAO层方法,进行增删改查操作。 下面是一个简单的示例,演示如何使用Hibernate进行增删改查操作: 1. 创建Hibernate配置文件hibernate.cfg.xml,指定数据库连接信息和实体类映射信息。 ``` <hibernate-configuration> <session-factory> <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test</property> <property name="hibernate.connection.username">root</property> <property name="hibernate.connection.password">root</property> <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property> <mapping class="com.example.User"/> </session-factory> </hibernate-configuration> ``` 2. 创建实体类User,使用注解将实体类映射到数据库表中。 ``` @Entity @Table(name = "users") public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(name = "name") private String name; @Column(name = "age") private int age; // getters and setters } ``` 3. 创建DAO层代码,使用Hibernate提供的API进行增删改查操作。 ``` public class UserDao { private SessionFactory sessionFactory; public void setSessionFactory(SessionFactory sessionFactory) { this.sessionFactory = sessionFactory; } public void save(User user) { Session session = sessionFactory.getCurrentSession(); session.save(user); } public void update(User user) { Session session = sessionFactory.getCurrentSession(); session.update(user); } public void delete(User user) { Session session = sessionFactory.getCurrentSession(); session.delete(user); } public User findById(Long id) { Session session = sessionFactory.getCurrentSession(); User user = (User) session.get(User.class, id); return user; } public List<User> findAll() { Session session = sessionFactory.getCurrentSession(); Query query = session.createQuery("from User"); List<User> users = query.list(); return users; } } ``` 4. 在应用程序中调用DAO层方法,进行增删改查操作。 ``` public class App { public static void main(String[] args) { ApplicationContext context = new ClassPathXmlApplicationContext("classpath:applicationContext.xml"); UserDao userDao = (UserDao) context.getBean("userDao"); // create user User user = new User(); user.setName("John Doe"); user.setAge(30); userDao.save(user); // update user User user = userDao.findById(1L); user.setName("Jane Smith"); userDao.update(user); // delete user User user = userDao.findById(1L); userDao.delete(user); // find all users List<User> users = userDao.findAll(); for (User u : users) { System.out.println(u.getName() + " - " + u.getAge()); } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值