简单的Hibernate使用入门

hibernate所需要的jar

dao层

User.hbm.xml

<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
   <!-- 配置表与实体对象的关系 -->
   <!-- package属性:填写一个包名.在元素内部凡是需要书写完整类名的属性,可以直接写简答类名了. -->
<hibernate-mapping package="com.hibernate.dao" >
<!-- 
class元素: 配置实体与表的对应关系的
name: 完整类名
table:数据库表名
-->
<class name="User" table="user" >
<!-- id元素:配置主键映射的属性
name: 填写主键对应属性名
column(可选): 填写表中的主键列名.默认值:列名会默认使用属性名
type(可选):填写列(属性)的类型.hibernate会自动检测实体的属性类型.
每个类型有三种填法: java类型|hibernate类型|数据库类型
not-null(可选):配置该属性(列)是否不能为空. 默认值:false
length(可选):配置数据库中列的长度. 默认值:使用数据库类型的最大长度
-->
<id name="id"  >
<!-- generator:主键生成策略(明天讲) -->
<generator class="native"></generator>
</id>
<!-- property元素:除id之外的普通属性映射
name: 填写属性名
column(可选): 填写列名
type(可选):填写列(属性)的类型.hibernate会自动检测实体的属性类型.
每个类型有三种填法: java类型|hibernate类型|数据库类型
not-null(可选):配置该属性(列)是否不能为空. 默认值:false
length(可选):配置数据库中列的长度. 默认值:使用数据库类型的最大长度
-->
<property name="userid" column="userid" ></property>
<property name="username" column="username" >
<!--  <column name="cust_name" sql-type="varchar" ></column> -->
</property>
<property name="password" column="cust_source" ></property>

</class>

</hibernate-mapping>

死记硬背的配置文件名字


<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>


<session-factory>
<!-- 
#hibernate.dialect org.hibernate.dialect.MySQLDialect
#hibernate.dialect org.hibernate.dialect.MySQLInnoDBDialect
#hibernate.dialect org.hibernate.dialect.MySQLMyISAMDialect
#hibernate.connection.driver_class com.mysql.jdbc.Driver
#hibernate.connection.url jdbc:mysql:///test
#hibernate.connection.username gavin
#hibernate.connection.password
-->
<!-- 数据库驱动 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<!-- 数据库url -->
<property name="hibernate.connection.url">jdbc:mysql:///user</property>
<!-- 数据库连接用户名 -->
<property name="hibernate.connection.username">root</property>
<!-- 数据库连接密码 -->
<property name="hibernate.connection.password">root</property>
<!-- 数据库方言
不同的数据库中,sql语法略有区别. 指定方言可以让hibernate框架在生成sql语句时.针对数据库的方言生成.
sql99标准: DDL 定义语言  库表的增删改查
 DCL 控制语言  事务 权限
 DML 操纵语言  增删改查
注意: MYSQL在选择方言时,请选择最短的方言.
-->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>


<!-- #hibernate.show_sql true 
#hibernate.format_sql true
-->
<!-- 将hibernate生成的sql语句打印到控制台 -->
<property name="hibernate.show_sql">true</property>
<!-- 将hibernate生成的sql语句格式化(语法缩进) -->
<property name="hibernate.format_sql">true</property>
<!-- 
## auto schema export  自动导出表结构. 自动建表
#hibernate.hbm2ddl.auto create 自动建表.每次框架运行都会创建新的表.以前表将会被覆盖,表数据会丢失.(开发环境中测试使用)
#hibernate.hbm2ddl.auto create-drop 自动建表.每次框架运行结束都会将所有表删除.(开发环境中测试使用)
#hibernate.hbm2ddl.auto update(推荐使用) 自动生成表.如果已经存在不会再生成.如果表有变动.自动更新表(不会删除任何数据).
#hibernate.hbm2ddl.auto validate 校验.不自动生成表.每次启动会校验数据库中表是否正确.校验失败.
-->
<property name="hibernate.hbm2ddl.auto">create</property>
<!-- 引入orm元数据
路径书写: 填写src下的路径
-->
<mapping resource="com/hibernate/dao/User.hbm.xml" />

</session-factory>

</hibernate-configuration>

测试:


运行成功:



  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您提供一个简单的示例,演示如何使用 Struts2 和 Hibernate 框架技术创建登录界面。 首先,您需要创建一个名为“login.jsp”的 JSP 页面,该页面将显示登录表单。在此页面中,您将需要使用 Struts2 标记库创建表单元素,例如文本框、密码框和提交按钮。示例代码如下: ``` <%@ taglib prefix="s" uri="/struts-tags" %> <html> <head> <title>Login Page</title> </head> <body> <h2>Login Form</h2> <s:form action="loginAction"> <s:textfield name="username" label="Username" /> <s:password name="password" label="Password" /> <s:submit value="Login" /> </s:form> </body> </html> ``` 接下来,您需要创建一个名为“LoginAction.java”的 Struts2 操作类,该类将处理提交的表单数据并验证用户凭据。在此类中,您将需要使用 Hibernate 框架技术从数据库中检索用户信息。示例代码如下: ``` import com.opensymphony.xwork2.ActionSupport; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.cfg.Configuration; import org.hibernate.query.Query; public class LoginAction extends ActionSupport { private String username; private String password; public String execute() { // Create session factory SessionFactory factory = new Configuration() .configure("hibernate.cfg.xml") .buildSessionFactory(); // Create session Session session = factory.getCurrentSession(); try { // Begin transaction session.beginTransaction(); // Query for user with matching username and password Query<User> query = session.createQuery("from User where username=:u and password=:p", User.class); query.setParameter("u", username); query.setParameter("p", password); User user = query.uniqueResult(); // Commit transaction session.getTransaction().commit(); // Check if user was found if (user != null) { return SUCCESS; } else { return LOGIN; } } catch (Exception e) { e.printStackTrace(); return ERROR; } finally { factory.close(); } } // Getter and setter methods } ``` 在上面的代码中,我们使用 Hibernate 的相关类从数据库中检索具有匹配用户名和密码的用户。如果找到了用户,则返回 Struts2 成功结果代码,否则返回登录结果代码。 最后,您需要在 Struts2 配置文件中定义操作和结果。在此示例中,我们将在“struts.xml”文件中创建以下条目: ``` <action name="loginAction" class="LoginAction"> <result name="success">welcome.jsp</result> <result name="login">login.jsp</result> <result name="error">error.jsp</result> </action> ``` 在上面的代码中,我们定义了一个名为“loginAction”的操作,该操作将调用“LoginAction”类的“execute”方法。我们还定义了三个结果,分别为“success”、“login”和“error”。如果用户成功登录,则返回“welcome.jsp”页面,否则返回“login.jsp”页面。 这就是使用 Struts2 和 Hibernate 框架技术创建登录界面的基本过程。希望这可以帮助您入门

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值