Product类
public class Product {
private String proid;
private String name;
private int num;
public String getProid() {
return proid;
}
public void setProid(String proid) {
this.proid = proid;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getNum() {
return num;
}
public void setNum(int num) {
this.num = num;
}
}
----------------------------------------------------------
Product.hbm.xml
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.soft.gread1">
<class name="Product" table="t_product">
<id name="proid">
<generator class="assigned"></generator>
</id>
<property name="name"></property>
<property name="num"></property>
</class>
</hibernate-mapping>
------------------------------------------------------------------------
测试类
import java.util.Date;
import org.hibernate.LockMode;
import org.hibernate.Session;
import junit.framework.TestCase;
import com.soft.gread1.Product;
import com.soft.gread1.comm.HibernateSessionFactory;
public class Test extends TestCase{
public void testSave1()
{
Session session=null;
try {
session=(Session) HibernateSessionFactory.getSession();
session.beginTransaction();
Product product=new Product();
product.setName("舒适达");
product.setProid("1000");
product.setNum(1000);
session.save(product);
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
}finally
{
HibernateSessionFactory.closeSession();
}
}
public void testLoad1()
{
Session session=null;
try {
session=(Session) HibernateSessionFactory.getSession();
session.beginTransaction();
/*
1. LockMode.NONE:无锁机制
2. LockMode.WRITE:Hibernate在Insert和Update记录的时候会自动获取
3. LockMode.READ:Hibernate在读取记录的时候会自动获取
4. LockMode.UPGRADE:利用数据库的for update子句加锁
5. LockMode.UPGRADE_NOWAIT:Oracle的特定实现,利用Oracle的for update nowait子句实现加锁
*/
Product product=(Product)session.load(Product.class, "1000",LockMode.UPGRADE);
System.out.println("操作员1--->Product:"+product.getProid());
System.out.println("操作员1--->Product:"+product.getName());
System.out.println("操作员1--->Product:"+product.getNum());
product.setNum(product.getNum()-200);
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
}finally
{
HibernateSessionFactory.closeSession();
}
}
public void testLoad2()
{
Session session=null;
try {
session=(Session) HibernateSessionFactory.getSession();
session.beginTransaction();
Product product=(Product)session.load(Product.class, "1000",LockMode.UPGRADE);
System.out.println("操作员2--->Product:"+product.getProid());
System.out.println("操作员2--->Product:"+product.getName());
System.out.println("操作员2--->Product:"+product.getNum());
product.setNum(product.getNum()-200);
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
}finally
{
HibernateSessionFactory.closeSession();
}
}
}