- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Hibernate-简化(单表RUDSQL查询)
(具体参考JavaWeb+hibernate3_v15.doc,这里项目所需知识点-单表添删改,多表查询用session.createSQLQuery(sql))
Hibernate概念: ORM技术,封装JDBC, OO操作DB (将db表 通过hbm.xml映射 为 POJO-entity-vo-po-bean)
表1(列…) 表2 ….
T1.hbm.xml T2.hbm.xml …..
类1(字段getter setter…) 类2 ….
(图示意)
几个类:
Configuration: 管理hib配置.cfg.xml(jdbc底层dbUrl,user,pwd,jdbcDriver,dialet..),hib映射文件*.hbm.xml
SessionFactory: 产生Session实例,缓存生成的SQL语句和Hib运行时使用的映射元数据(hib3.2自动生成)
Configuration conf=new Configuration().configure();//configure(resource)
SessionFactory hSessionFactory=conf.buildSessionFactory();
Session session=hSessionFactory.getSession();
Session:持久化管理器,代表与DB间的一次操作(多个CRUD),用完需关闭。
Transaction:hib的CUD操作必须Transaction commit,默认autoCommit=false/ jdbc为ture
My DB透视图操作 (为HIB配置准备,specify DB Connection Detail)
myEclipse新建proj—hibDemo,open-perspective—myeclipse db explorer
new DB Connection: MySQL J/connector 填写参数
Add Jars(驱动类库 ):mysql-connector-java-5.1.16-bin.jar org.gjt.mm.mysql.Driver
连上DB后:
SQL测试:展开myDBConn/Connected to mysql 右击/new SQL Editor 在窗口中写SQL后执行
2. 查看ER图:右击库empDB,new ER Diagram,选择项目hibDemo目录为er图存放目录,选择有主外键关系的表(如emp,department…)
create database empdb2;
use empdb2;
create table department(
id int auto_increment primary key,
name varchar(50) not null
);
create table interesting(
id int auto_increment primary key,
name varchar(255) not null
);
create table emp(
id int auto_increment primary key,
name varchar(255) not null,
sex char(1) default M check(sex in(M,F)),
department_id int references department(id)
);
create table emp_interesting( //M:M的中间表,hib建议保留外键字段即可
//id int auto_increment primary key,
emp_id int references emp(id),
interesting_id int references interesting(id)
);
Hib步骤(hibDemo):添加HIB支持并生成HibSessionFactory类;生成POJO类和映射文件;操作代码DAO
1.添加HIB支持:右击项目hibDemo,选myEclipse/Add Hib Capabilities, hib3.2,选copy lib jars to proj folder(便于项目移植)看到hibernate.cfg.xml是hib配置文件,进一步设置如下:db driver (可下拉选择来自DB Explorer设置):
enable dynamic table creattion
创建H
文档评论(0)