摘要:前言前面的我们使用的是一个表的操作,但我们实际的开发中不可能只使用一个表的因此,本博文主要讲解关联映射集合映射需求分析当用户购买商品,用户可能有多个地址。数据库表我们一般如下图一样设计数据库表,一般我们不会在表设计多个列来保存地址的。
前言
前面的我们使用的是一个表的操作,但我们实际的开发中不可能只使用一个表的...因此,本博文主要讲解关联映射
集合映射需求分析:当用户购买商品,用户可能有多个地址。
数据库表我们一般如下图一样设计数据库表,一般我们不会在User表设计多个列来保存地址的。因为每个用户的地址个数都不一的,会造成数据冗余
创建两张数据表,一张保存着用户的信息,一张保存着地址的信息。地址表使用外键来引用用户表
实体由于地址只是使用String类型来保存着,那么我们直接使用一个User对象就可以了
public class User { private String id; private String username; private String password; private Set映射文件address; //各种setter和getter
测试:
package zhongfucheng.domain; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.classic.Session; /** * Created by ozc on 2017/5/6. */ public class App { public static void main(String[] args) { //创建对象 User user = new User(); user.setUsername("123"); user.setPassword("1234"); user.getAddress().add("广州"); //获取加载配置管理类 Configuration configuration = new Configuration(); //加载User的映射文件! configuration.configure().addClass(User.class); //创建Session工厂对象 SessionFactory factory = configuration.buildSessionFactory(); //得到Session对象 Session session = factory.openSession(); //使用Hibernate操作数据库,都要开启事务,得到事务对象 Transaction transaction = session.getTransaction(); //开启事务 transaction.begin(); session.save(user); //提交事务 transaction.commit(); //关闭Session session.close(); } }List集合映射配置
既然我们现在已经会了如何配置Set集合了,List集合又怎么配置呢??
想一下,List集合和Set集合有什么区别...List集合是有序的,因此要多配置一个列来维护数据的有序性!
Map集合映射配置
Map集合和Collection集合的区别就是键值对模型,那么在配置的时候多一个key即可!
一对多和多对一
上面我们讲解了集合映射是怎么配置的,那集合装载的元素有没有可能是对象呢??而不是简单的String类型..那个就太多了!一般地,我们集合装载的都是对象,而不是简单的String,如果我们的装载在集合的数据有很多类型,那么String就不能用了!...
需求:部门与员工之间的关系
一个部门有多个员工; 【一对多】
多个员工,属于一个部门 【多对一】
设计数据库表员工表应该使用一个外键来记住部门表。这样才可以维护员工和部门之间的关系
设计实体部门实体要使用一个集合来记住所有的员工,员工要使用一个对象引用着部门
Dept.java
package zhongfucheng.domain; import java.util.HashSet; import java.util.Set; /** * Created by ozc on 2017/5/6. */ public class Dept { private int id ; private Setset = new HashSet<>(); private String deptName; public String getDeptName() { return deptName; } public void setDeptName(String deptName) { this.deptName = deptName; } public int getId() { return id; } public void setId(int id) { this.id = id; } public Set getSet() { return set; } public void setSet(Set set) { this.set = set; } }
Employee.java
package zhongfucheng.domain; /** * Created by ozc on 2017/5/6. */ public class Employee { private int id; private String empName; private double salary; private Dept dept; public Dept getDept() { return dept; } public void setDept(Dept dept) { this.dept = dept; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getEmpName() { return empName; } public void setEmpName(String empName) { this.empName = empName; } public double getSalary() { return salary; } public void setSalary(double salary) { this.salary = salary; } }映射分析
我们在写映射配置文件之前,分析一下怎么写。以部门映射配置文件为例...
现在使用了一个Set集合来维护与员工的关系,Set集合的类型是员工对象...因此在映射文件中需要以下几点
映射集合属性的名称(employees)
映射集合对应的数据表(employee)
对应的数据表的外键字段(dept_id)
集合中的元素类型(Employee)【通过这个类型,Hibernate就可以找到对应类型的映射文件,从而得到对应的信息!】
部门映射配置文件员工映射配置文件
在“一”的一方测试
package zhongfucheng.domain; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.classic.Session; /** * Created by ozc on 2017/5/6. */ public class App { public static void main(String[] args) { //创建对象 Dept dept = new Dept(); dept.setDeptName("开发部"); Employee zs = new Employee(); zs.setEmpName("张珊"); zs.setSalary(1111); Employee ls = new Employee(); ls.setEmpName("李四"); ls.setSalary(2222); //添加关系 dept.getSet().add(zs); dept.getSet().add(ls); //获取加载配置管理类 Configuration configuration = new Configuration(); //加载User的映射文件! configuration.configure().addClass(Dept.class).addClass(Employee.class); //创建Session工厂对象 SessionFactory factory = configuration.buildSessionFactory(); //得到Session对象 Session session = factory.openSession(); //使用Hibernate操作数据库,都要开启事务,得到事务对象 Transaction transaction = session.getTransaction(); //开启事务 transaction.begin(); session.save(dept); session.save(zs); session.save(ls); //提交事务 transaction.commit(); //关闭Session session.close(); } }
Hibernate执行了5条SQL语句
在“多”的一方测试package zhongfucheng.domain; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.classic.Session; /** * Created by ozc on 2017/5/6. */ public class App { public static void main(String[] args) { //创建对象 Dept dept = new Dept(); dept.setDeptName("开发部"); Employee zs = new Employee(); zs.setEmpName("张珊"); zs.setSalary(1111); Employee ls = new Employee(); ls.setEmpName("李四"); ls.setSalary(2222); //维护关系 zs.setDept(dept); ls.setDept(dept); //获取加载配置管理类 Configuration configuration = new Configuration(); //加载User的映射文件! configuration.configure().addClass(Dept.class).addClass(Employee.class); //创建Session工厂对象 SessionFactory factory = configuration.buildSessionFactory(); //得到Session对象 Session session = factory.openSession(); //使用Hibernate操作数据库,都要开启事务,得到事务对象 Transaction transaction = session.getTransaction(); //开启事务 transaction.begin(); session.save(dept); session.save(zs); session.save(ls); //提交事务 transaction.commit(); //关闭Session session.close(); } }
Hibernate执行了3条SQL
一对多和多对一总结在一对多与多对一的关联关系中,保存数据最好的通过多的一方来维护关系,这样可以减少update语句的生成,从而提高hibernate的执行效率!
配置一对多与多对一, 这种叫“双向关联”
只配置一对多, 叫“单项一对多”
只配置多对一, 叫“单项多对一”
值得注意是:配置了哪一方,哪一方才有维护关联关系的权限!
当我在部门中不配置员工的关联关系了,那么在操作部门的时候就不能得到员工的数据了【也就是:在保存部门时,不能同时保存员工的数据】
多对多映射需求:一个项目由多个员工开发,一个员工开发多个项目
设计数据库表一般地,如果是多对多的映射,我们都会使用一张中间表来保存它们的关联关系....
设计实体我们在设计实体的时候,一般是核心数据表对应一个JavaBean实体【中间表并不是核心数据表】,那么我们将会设计两个JavaBean对象
project.java
package zhongfucheng.many2many; import java.util.HashSet; import java.util.Set; /** * Created by ozc on 2017/5/7. */ public class Project { private int projectId; private String projectName; //使用Set集合与developer实体维护关系 private Setdevelopers = new HashSet<>(); public int getProjectId() { return projectId; } public void setProjectId(int projectId) { this.projectId = projectId; } public String getProjectName() { return projectName; } public void setProjectName(String projectName) { this.projectName = projectName; } public Set getDevelopers() { return developers; } public void setDevelopers(Set developers) { this.developers = developers; } }
developer.java
package zhongfucheng.many2many; import java.util.HashSet; import java.util.Set; /** * Created by ozc on 2017/5/7. */ public class Developer { private int developerId; private String developerName; //使用Set集合来维护与Project关系 private Set映射配置文件projects = new HashSet<>(); public int getDeveloperId() { return developerId; } public void setDeveloperId(int developerId) { this.developerId = developerId; } public String getDeveloperName() { return developerName; } public void setDeveloperName(String developerName) { this.developerName = developerName; } public Set getProjects() { return projects; } public void setProjects(Set projects) { this.projects = projects; } }
以项目映射文件为例:我们不急着写,首先来分析一下关键点......想要在多对多映射中产生正确的关联关系,下面几步必不可少:
配置映射集合的属性(developers)
映射集合对应的中间表(developer_project)
中间表的外键字段(project_id)
集合元素的类型(Developer)
中间表另外的外键字段(developer_id)
Project和Developer的映射文件都需要这几个关键步骤
Project映射文件Developer映射文件
测试
package zhongfucheng.many2many; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.classic.Session; /** * Created by ozc on 2017/5/6. */ public class App2 { public static void main(String[] args) { /* * * * Project Developer 电商系统 曹吉 王春 OA系统 王春 老张 */ //创建对象 Developer cj = new Developer(); Developer wc = new Developer(); Developer lz = new Developer(); Project ds = new Project(); Project oa = new Project(); //设置对象的数据 cj.setDeveloperName("曹吉"); wc.setDeveloperName("王春"); lz.setDeveloperName("老张"); oa.setProjectName("OA系统"); ds.setProjectName("电商系统"); //使用Project来关联数据【在多对多中,一样的】 oa.getDevelopers().add(wc); oa.getDevelopers().add(lz); ds.getDevelopers().add(cj); ds.getDevelopers().add(wc); //获取加载配置管理类 Configuration configuration = new Configuration(); //加载User的映射文件! configuration.configure().addClass(Developer.class).addClass(Project.class); //创建Session工厂对象 SessionFactory factory = configuration.buildSessionFactory(); //得到Session对象 Session session = factory.openSession(); //使用Hibernate操作数据库,都要开启事务,得到事务对象 Transaction transaction = session.getTransaction(); //开启事务 transaction.begin(); //在Project映射文件中设置级联保存了 session.save(oa); session.save(ds); //提交事务 transaction.commit(); //关闭Session session.close(); } }
执行了9条SQL语句,数据库中的记录也是正确的。
一对一的映射需求:用户与身份证信息..一个用户对应一个身份证
数据库表设计对于数据库表设计我们有两种方式
第一种:在身份证的数据表中设置一个外键来维护用户的关系,这个外键也应该是唯一的【一个用户对应一张身份证】
第二种:在身份证的数据表中使用主键+外键的方式来维护用户的关系。
设计实体idCard.java
package zhongfucheng.one2one; /** * Created by ozc on 2017/5/7. */ public class IdCard { private int idCardId; private String idCardName; //维护与用户之间的关系 private User user ; public int getIdCardId() { return idCardId; } public void setIdCardId(int idCardId) { this.idCardId = idCardId; } public String getIdCardName() { return idCardName; } public void setIdCardName(String idCardName) { this.idCardName = idCardName; } public User getUser() { return user; } public void setUser(User user) { this.user = user; } }
User.java
package zhongfucheng.one2one; /** * Created by ozc on 2017/5/7. */ public class User { private int userId; private String userName; //维护与身份证一对一的关系 private IdCard idCard ; public int getUserId() { return userId; } public void setUserId(int userId) { this.userId = userId; } public String getUserName() { return userName; } public void setUserName(String userName) { this.userName = userName; } public IdCard getIdCard() { return idCard; } public void setIdCard(IdCard idCard) { this.idCard = idCard; } }第一种方式映射文件
我们有两种方式来设计数据库中的表实现一对一的关系,首先我们来挑比较熟悉的外键方式来写映射文件
user映射文件idCard映射文件
测试
要使用IdCart来维护User的关联关系。
如果使用User来维护idCart的关联关系,idCart的外键列是为NULL的,因为重头到尾我们都没有给它赋值
而使用IdCart来维护User,是外键值是根据User的主键id来生成的
package zhongfucheng.one2one; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.classic.Session; /** * Created by ozc on 2017/5/6. */ public class App3 { public static void main(String[] args) { //创建对象 User user = new User(); IdCard idCard = new IdCard(); //设置对象的数据 user.setUserName("你好"); idCard.setIdCardName("身份证001"); //一对一关联数据 idCard.setUser(user); //获取加载配置管理类 Configuration configuration = new Configuration(); //加载User的映射文件! configuration.configure().addClass(User.class).addClass(IdCard.class); //创建Session工厂对象 SessionFactory factory = configuration.buildSessionFactory(); //得到Session对象 Session session = factory.openSession(); //使用Hibernate操作数据库,都要开启事务,得到事务对象 Transaction transaction = session.getTransaction(); //开启事务 transaction.begin(); //保存对象的数据,idCard配置文件使用级联保存 session.save(idCard); //提交事务 transaction.commit(); //关闭Session session.close(); } }第二种方式映射文件
因为IdCart使用userId作为了主键,因此需要在JavaBean中配置多一个属性UserId...其他的都不用变
private int userId; public int getUserId() { return userId; } public void setUserId(int userId) { this.userId = userId; }
在Hibernate入门篇讲解配置的时候,在generator节点下还有一个属性没有讲解,也就是foreign属性...现在来填坑了..
idCard映射文件idCart的映射文件主要在于:将主键也映射成外键来使用,这就需要用到foreign属性值了
使用
user映射文件user
测试
package zhongfucheng.one2one2.one2one; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.classic.Session; /** * Created by ozc on 2017/5/6. */ public class App4 { public static void main(String[] args) { //创建对象 User user = new User(); IdCard idCard = new IdCard(); //设置对象的数据 user.setUserName("你好3"); idCard.setIdCardName("身份证003"); idCard.setIdCardId(4235); //一对一关联数据 idCard.setUser(user); //获取加载配置管理类 Configuration configuration = new Configuration(); //加载User的映射文件! configuration.configure().addClass(User.class).addClass(IdCard.class); //创建Session工厂对象 SessionFactory factory = configuration.buildSessionFactory(); //得到Session对象 Session session = factory.openSession(); //使用Hibernate操作数据库,都要开启事务,得到事务对象 Transaction transaction = session.getTransaction(); //开启事务 transaction.begin(); //保存对象的数据,idCard配置文件使用级联保存 session.save(idCard); //提交事务 transaction.commit(); //关闭Session session.close(); } }组件映射
Java主要的类主要有两种方式
组合关系,组合关系对应的就是组件映射
继承关系,继承关系对应的就是继承映射
组件映射实际上就是将组合关系的数据映射成一张表,组件类和被包含的组件类映射成一张表
有的时候,两个类的关系明显不是继承关系,但两个类的亲密程度很高,在一个类里边需要用到另外一个类...那么就在类中定义一个变量来维护另一个类的关系,这种就叫组合关系!
需求:汽车和轮子。汽车需要用到轮子,但是轮子的爸爸不可能是汽车吧?
设计数据库 设计实体Wheel.java
public class Wheel { private int count; private int size; public int getCount() { return count; } public void setCount(int count) { this.count = count; } public int getSize() { return size; } public void setSize(int size) { this.size = size; } }
Car.java,使用变量维护Wheel
package zhongfucheng.aa; /** * Created by ozc on 2017/5/7. */ public class Car { private int id; private String name; private Wheel wheel; public Wheel getWheel() { return wheel; } public void setWheel(Wheel wheel) { this.wheel = wheel; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }映射表
使用了一个新标签
测试
package zhongfucheng.aa; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.classic.Session; /** * Created by ozc on 2017/5/6. */ public class App5 { public static void main(String[] args) { //创建对象 Wheel wheel = new Wheel(); Car car = new Car(); //设置属性 wheel.setCount(43); wheel.setSize(22); car.setName("宝马"); //维护关系 car.setWheel(wheel); //获取加载配置管理类 Configuration configuration = new Configuration(); configuration.configure().addClass(Car.class); //创建Session工厂对象 SessionFactory factory = configuration.buildSessionFactory(); //得到Session对象 Session session = factory.openSession(); //使用Hibernate操作数据库,都要开启事务,得到事务对象 Transaction transaction = session.getTransaction(); //开启事务 transaction.begin(); session.save(car); //提交事务 transaction.commit(); //关闭Session session.close(); } }传统方式继承
需求:动物、猫、猴子。猫继承着动物
传统方式继承的特点就是:有多少个子类就写多少个配置文件.
表结构我们的表应该是这样的:id和name从Animal中继承,catchMouse是子类的具体行为。
实体Animal.java
package zhongfucheng.aa; // 动物类 public abstract class Animal { private int id; private String name; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
Cat.java继承着Animail
package zhongfucheng.aa; public class Cat extends Animal{ // 抓老鼠 private String catchMouse; public String getCatchMouse() { return catchMouse; } public void setCatchMouse(String catchMouse) { this.catchMouse = catchMouse; } }映射文件
简单继承的映射文件很好写,在属性上,直接写父类的属性就可以了。
但是也有致命的缺点:如果子类有很多,就需要写很多的配置文件
测试
package zhongfucheng.aa; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.classic.Session; public class App5 { public static void main(String[] args) { //创建对象 Cat cat = new Cat(); //设置属性 cat.setName("大花猫"); cat.setCatchMouse("捉大老鼠"); //获取加载配置管理类 Configuration configuration = new Configuration(); configuration.configure().addClass(Cat.class); //创建Session工厂对象 SessionFactory factory = configuration.buildSessionFactory(); //得到Session对象 Session session = factory.openSession(); //使用Hibernate操作数据库,都要开启事务,得到事务对象 Transaction transaction = session.getTransaction(); //开启事务 transaction.begin(); session.save(cat); //如果取数据时候Animal父类接收的话,需要给出Anmail的全名 //提交事务 transaction.commit(); //关闭Session session.close(); } }把所有子类映射成一张表
前面我们采用的是:每个子类都需要写成一个配置文件,映射成一张表...
如果子类的结构很简单,只比父类多几个属性。就像上面的例子...我们可以将所有的子类都映射成一张表中
但是呢,这样是不符合数据库设计规范的.....因为表中的数据可能是猫,可能是猴子...这明显是不合适的...
由于表中可能存在猫,存在猴子,为了区分是什么类型的。我们需要使用鉴别器
我们了解一下...
数据表 实体实体和上面雷同,只多了一个猴子的实体表
Monkey.java
public class Monkey extends Animal { // 吃香蕉 private String eatBanana; public String getEatBanana() { return eatBanana; } public void setEatBanana(String eatBanana) { this.eatBanana = eatBanana; } }映射文件
使用了subClass这个节点和鉴别器
测试
加载的是Animal父类的映射文件。保存的是cat和monkey。
package zhongfucheng.aa; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.classic.Session; public class App5 { public static void main(String[] args) { //创建对象 Cat cat = new Cat(); Monkey monkey = new Monkey(); //设置属性 cat.setName("大花猫"); cat.setCatchMouse("小老鼠"); monkey.setEatBanana("吃香蕉"); monkey.setName("大猴子"); //获取加载配置管理类 Configuration configuration = new Configuration(); //加载Animal的映射文件! configuration.configure().addClass(Animal.class); //创建Session工厂对象 SessionFactory factory = configuration.buildSessionFactory(); //得到Session对象 Session session = factory.openSession(); //使用Hibernate操作数据库,都要开启事务,得到事务对象 Transaction transaction = session.getTransaction(); //开启事务 transaction.begin(); session.save(cat); session.save(monkey); //提交事务 transaction.commit(); //关闭Session session.close(); } }每个类映射一张表(3张表)
父类和子类都各对应一张表。那么就有三张表了
这种结构看起来是完全面向对象,但是表之间的结构会很复杂,插入一条子类的信息,需要两条SQL
数据表设计 映射文件使用到了
测试
package zhongfucheng.aa; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.classic.Session; public class App5 { public static void main(String[] args) { //创建对象 Cat cat = new Cat(); Monkey monkey = new Monkey(); //设置属性 cat.setName("大花猫"); cat.setCatchMouse("小老鼠"); monkey.setEatBanana("吃香蕉"); monkey.setName("大猴子"); //获取加载配置管理类 Configuration configuration = new Configuration(); //加载类对应的映射文件! configuration.configure().addClass(Animal.class); //创建Session工厂对象 SessionFactory factory = configuration.buildSessionFactory(); //得到Session对象 Session session = factory.openSession(); //使用Hibernate操作数据库,都要开启事务,得到事务对象 Transaction transaction = session.getTransaction(); //开启事务 transaction.begin(); session.save(cat); session.save(monkey); //提交事务 transaction.commit(); //关闭Session session.close(); } }
每保存一个子类对象需要两条SQL语句!
(推荐)每个子类映射一张表, 父类不对应表(2张表)使用过了一张表保存所有子类的数据,这不符合数据库设计规范
每个子类、父类都拥有一张表..表结构太过于繁琐..添加信息时,过多的SQL
我们即将使用的是:每个子类映射成一张表,父类不对应表...这和我们传统方式继承是一样的。只不过在hbm.xml文件中使用了
想要父类不映射成数据库表,只要在class中配置为abstract即可
使用了union-subclass节点,主键就不能采用自动增长策略了。我们改成UUID即可。当然啦,对应的实体id类型要改成String
测试
package zhongfucheng.aa; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.classic.Session; public class App5 { public static void main(String[] args) { //创建对象 Cat cat = new Cat(); Monkey monkey = new Monkey(); //设置属性 cat.setName("大花猫"); cat.setCatchMouse("小老鼠"); monkey.setEatBanana("吃香蕉"); monkey.setName("大猴子"); //获取加载配置管理类 Configuration configuration = new Configuration(); //加载类对应的映射文件! configuration.configure().addClass(Animal.class); //创建Session工厂对象 SessionFactory factory = configuration.buildSessionFactory(); //得到Session对象 Session session = factory.openSession(); //使用Hibernate操作数据库,都要开启事务,得到事务对象 Transaction transaction = session.getTransaction(); //开启事务 transaction.begin(); session.save(cat); session.save(monkey); //提交事务 transaction.commit(); //关闭Session session.close(); } }组件映射和继承映射总结
由于我们的传统继承映射每个子类都对应一个配置文件,这样十分麻烦。因此.hbm.xml就给出了几个节点供我们使用,分别有以下的情况:
子类父类共有一张表subclass
不符合数据库设计规范
需要使用鉴别器
子类、父类都有自己的表joined-subclass,那么就是三张表
表的结构太过繁琐
插入数据时要生成SQL至少就要两条
子类拥有自己的表、父类不对应表【推荐】union-subclass
父类不对应表要使用abstract来修饰
主键的id不能使用自增长策略,修改成UUID就好了。对应的JavaBean的id设置成String就好
如果文章有错的地方欢迎指正,大家互相交流。习惯在微信看技术文章,想要获取更多的Java资源的同学,可以关注微信公众号:Java3y
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/68696.html
摘要:要是使用到日历的话,我们想到使用这个日历类上面仅仅是我个人总结的要点,如果有错误的地方还请大家给我指正。 纳税服务系统总结 纳税服务系统是我第一个做得比较大的项目(不同于javaWeb小项目),该项目系统来源于传智Java32期,十天的视频课程(想要视频的同学关注我的公众号就可以直接获取了) 我跟着练习一步一步完成需求,才发觉原来Java是这样用来做网站的,Java有那么多的类库,页面...
摘要:前言由于写的文章已经是有点多了,为了自己和大家的检索方便,于是我就做了这么一个博客导航。 前言 由于写的文章已经是有点多了,为了自己和大家的检索方便,于是我就做了这么一个博客导航。 由于更新比较频繁,因此隔一段时间才会更新目录导航哦~想要获取最新原创的技术文章欢迎关注我的公众号:Java3y Java3y文章目录导航 Java基础 泛型就这么简单 注解就这么简单 Druid数据库连接池...
摘要:对象状态中对象的状态临时瞬时状态持久化状态游离状态学习的对象状态是为了更清晰地知道的设计思想,以及是一级缓存的基础当然啦,也就一点点知识临时瞬时状态当我们直接出来的对象就是临时瞬时状态的该对象还没有被持久化没有保存在数据库中不受的管理持久化 对象状态 Hibernate中对象的状态: 临时/瞬时状态 持久化状态 游离状态 学习Hibernate的对象状态是为了更清晰地知道Hiber...
摘要:我来看一下查询结果我们的实体与映射表中,实体是没有关联其他的字段的,仅仅是写出了该实体的自带的属性。 Mybatis【多表连接】 我们在学习Hibernate的时候,如果表涉及到两张的话,那么我们是在映射文件中使用..等标签将其的映射属性关联起来的...那么在我们Mybatis中又怎么做呢??? 先来回顾一下我们SQL99的语法: 一)内连接(等值连接):查询客户姓名,订单编号,订单...
摘要:当你真正到公司里面从事了几年开发之后,你就会同意我的说法利用找工作,需要的就是项目经验,项目经验就是理解项目开发的基本过程,理解项目的分析方法,理解项目的设计思 Java就是用来做项目的!Java的主要应用领域就是企业级的项目开发!要想从事企业级的项目开发,你必须掌握如下要点: 1、掌握项目开发的基本步骤 2、具备极强的面向对象的分析与设计技巧 3、掌握用例驱动、以架构为核心的主流开发...
阅读 1993·2023-04-25 22:50
阅读 2814·2021-09-29 09:35
阅读 3357·2021-07-29 10:20
阅读 3132·2019-08-29 13:57
阅读 3319·2019-08-29 13:50
阅读 3010·2019-08-26 12:10
阅读 3505·2019-08-23 18:41
阅读 2598·2019-08-23 18:01