首页 > 编程知识 正文

java将多个类映射到一个表(java将多个类映射到一个表格)

时间:2023-12-03 11:56:27 阅读:311678 作者:AKEC

本文目录一览:

  • 1、java如何将一张表的数据映射到另一张表中,两张表的数据结构完全不同
  • 2、怎么用java来实现数据库表的关联,例如一个用户对应一个表。
  • 3、java实现遍历哈希映射表map的方法汇总
  • 4、java中的映射是怎样实现的?

java如何将一张表的数据映射到另一张表中,两张表的数据结构完全不同

别,千万别用程序去控制一张映射表(这张表不是你这个项目用的吧,应该是作为镜像给别人的吧)

看你这个需求应该是纯数据需求,一个触发器就解决了的事儿,虽说sql可能写的飘逸些

建议:触发器解决

怎么用java来实现数据库表的关联,例如一个用户对应一个表。

用户表就对应一个用户的类,你这个用户类里面的属性跟数据库表里面的字段一一对应,查询的时候,查出用户表中的一条记录,就对应一个用户对象啦。

java实现遍历哈希映射表map的方法汇总

方法/步骤

1、JDK,开发必须的环境

2、IDE,还是推荐Eclipse,如果你的电脑够快,可以安装Idea,用过一次,太吃内存,就被抛弃了,但是很多同行都在推荐,听说很好。

现在开始进入今天的正题,使用Java代码遍历Map集合的方法汇总。

1、创建一个Java类,命名为MapTest

2、创建一个Map集合,并定义类型和put值:

3、循环遍历Map集合的第一种方法,代码如下:

/**

* 第一种

* foreach循环进行遍历

* 遍历的是key值,然后通过get(key)或者值

* key和keyset

*/

private static void firstMethod(HashMapInteger, String map){

System.out.println("foreach循环进行遍历");

for (Integer key : map.keySet()) {

System.out.println("key:"+key+"对应的值为:"+map.get(key));

}

}

4、通过Iterator遍历Map集合的第二种方法获取,代码如下:

/**

* 第二种

* 通过Iterator遍历获取

* 和List的遍历原理相同

*/

public static void secondMethod(HashMapInteger, String map){

System.out.println("通过Iterator遍历获取");

IteratorEntryInteger, String inte = map.entrySet().iterator();

while(inte.hasNext()){

Map.EntryInteger, String m = inte.next();

System.out.println("key:"+m.getKey()+"对应的值为:"+m.getValue());

}

}

5、通过map方法map.entrySet()遍历获取值的第三种方法,代码如下:

/**

* 第三种,通过map方法map.entrySet()遍历获取值

*/

public static void thirdMethod(HashMapInteger, String map){

System.out.println("第三种方式:entry");

for (EntryInteger, String str : map.entrySet()) {

System.out.println("key:"+str.getKey()+"对应的值为:"+str.getValue());

}

}

6、通过for循环,map.values()循环遍历获取值的第四种方法,代码如下:

这种方法是直接获取值,不获取key值:

/**

* 第四种,通过for循环,map.values()循环遍历获取值 直接获取值

*/

public static void fourthMethod(HashMapInteger, String map) {

System.out.println("通过map.values()循环遍历直接获取值");

for (String string : map.values()) {

System.out.println("map的值为:" + string);

}

}

7

7、不管是遍历Map还是List的,其本质都是获取对应的值,程序员在开发中可以根据开发场景适当的选择各种方法,但是理解其本质才是最主要的。

java中的映射是怎样实现的?

建议做法如下:

第一,写一个符合javaBean标准的实体类,类的属性名称和类型分别与数据库的字段对应,并加上无参构造方法和get、set方法;

第二,使用注解配置映射关系,用@Entity注解该类是一个实体类,用@Table(name = "表名")注解该实体类映射的表名,通过在每一个属性的get方法上添加@Column(name = "列名")注解该属性映射的列;

第三,配置主键,找出表主键映射的那个属性,用@Id在该属性的get方法上注解该属性为Id。(根据具体需要,可能还要做一些更详细的配置)

参考代码如下:

import javax.persistence.Column;

import javax.persistence.Entity;

import javax.persistence.Id;

import javax.persistence.Table;

import org.hibernate.annotations.Parameter;

/**

 * 

 * 用户

 */

@Entity //说明该类是实体类

@Table(name = "USER")//说明该类映射的是表USER

public class TUser implements java.io.Serializable {

    private String userID; // 用户id

    private String userName; // 用户名称

    private String loginName; // 登录名称

    private String password; // 密码

    private Integer status; // 状态

    private java.util.Date lastLoginTime; // 上次登录时间

    private java.util.Date regTime; // 注册时间

    

    @Id//说明该属性映射的是表USER的主键

    @Column(name = "UserID", unique = true, nullable = false)

    //该属性映射的是表USER的UserId字段,非空且唯一

    public String getUserID() {

        return this.userID;

    }

    public void setUserID(String userID) {

        this.userID = userID;

    }

    @Column(name = "UserName")

    public String getUserName() {

        return userName;

    }

    public void setUserName(String userName) {

        this.userName = userName;

    }

    @Column(name = "LoginName")

    public String getLoginName() {

        return this.loginName;

    }

    public void setLoginName(String loginName) {

        this.loginName = loginName;

    }

    @Column(name = "Password")

    public String getPassword() {

        return this.password;

    }

    public void setPassword(String password) {

        this.password = password;

    }

    @Column(name = "Status")

    public Integer getStatus() {

        return status;

    }

    public void setStatus(Integer status) {

        this.status = status;

    }

    @Column(name = "LastLoginTime")

    public java.util.Date getLastLoginTime() {

        return lastLoginTime;

    }

    public void setLastLoginTime(java.util.Date lastLoginTime) {

        this.lastLoginTime = lastLoginTime;

    }

    @Column(name = "RegTime")

    public java.util.Date getRegTime() {

        return regTime;

    }

    public void setRegTime(java.util.Date regTime) {

        this.regTime = regTime;

    }

    @Override

    public int hashCode() {

        int prime = 0;

        prime += this.getUserID().hashCode();

        return prime;

    }

    @Override

    public boolean equals(Object obj) {

        boolean isEquals = false;

        if (obj != null  this.getClass() == obj.getClass()) {

            TUser clazz = (TUser) obj;

            if (clazz.getUserID().equals(this.getUserID()))

                isEquals = true;

            return isEquals;

        }

        return isEquals;

    }

}

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。