对象关系映射ORM

目录

ORM【重要】

[1、 什么是ORM](#1、 什么是ORM)

[2、 实体类](#2、 实体类)

[3、 ORM改造登录案例](#3、 ORM改造登录案例)


ORM【重要】

1、 什么是ORM

目前使用JDBC完成了CRUD,但是现在是进行CRUD,增删改方法要设计很多参数,查询的方法需要设计集合才能返回.


在实际开发中,我们需要将零散的数据封装到对象处理.
ORM (Object Relational Mapping) 对象关系映射

是指数据库表Java的实体类有关系,可以进行映射

  • 数据库表 --> Java的类

    • tb_user ---> User.java
  • 字段 --> 类的属性

    • id int --> private int id;

    • username varchar --> private String username;

    • ...

  • 一行数据 --> 类的对象

  • 一行数据内每个列的值 --> 对象的属性值

2、 实体类

实体类: 数据表中零散数据的载体,用来封装数据.

  • 表名 设计 类名

  • 将列名设计成属性名

    • id --> id

    • create_time --> createTime (下划线转驼峰)

  • 将列的数据类型设计成属性的数据类型

  • 给类提供对应set get


一般项目中一个表就会对应一个实体类,所有的实体类都会放在model/entity/pojo/javabeen包结构中


将来写项目,数据库设计完,搭建完项目,第一件事件就是根据表结构,创建实体类

java 复制代码
public class User {   // 实体类,是表名
    // 属性是字段名
    private int id;
    private String username;
    private String password;
    private String phone;
    private Date createTime;
    private double money;
    private int sex;
    
    // setter getter...
}

3、 ORM改造登录案例

需求变更: 登录,如果成功,返回该用户所有信息

java 复制代码
public class Demo5_login_orm {
​
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入用户名:" );
        String username = scanner.nextLine( );
​
        System.out.println("请输入密  码:" );
        String password = scanner.nextLine( );
​
        User user = login(username, password);
​
        if (user != null) {
            System.out.println("登录成功,信息如下" );
            System.out.println(user );
        } else {
            System.out.println("登录失败,用户名或密码错误!" );
        }
    }
​
    // 需求变更: 登录,如果成功,返回该用户所有信息
    // 数据信息使用User对象封装
    public static User login(String username, String password) {
        Connection conn = null;
        Statement s = null;
        ResultSet rs = null;
        try {
            // 1加载驱动
            Class.forName("com.mysql.jdbc.Driver");
            // 2获得连接
            conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/java2403?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimeZone=UTC",
                    "root", "123456");
            // 3获得执行语句对象
            s = conn.createStatement( );
​
            String sql = "select * from tb_user where username = '"+username+"' and password = '"+password+"'";
            System.out.println("拼接后的sql: " + sql );
            // 4执行sql
            rs = s.executeQuery(sql);
            if (rs.next()) {// 登录成功,从结果集取出数据
                int id = rs.getInt("id");
                String uname = rs.getString("username");
                String pwd = rs.getString("password");
                String phone = rs.getString("phone");
                Date createTime = rs.getDate("create_time");
                double money = rs.getDouble("money");
                int sex = rs.getInt("sex");
​
                User user = new User(id,uname,pwd,phone,createTime,money,sex);
                return user;
            }
        } catch (Exception e) {
            e.printStackTrace( );
        } finally {
            // 5关流
            try {
                rs.close();
                s.close( );
                conn.close( );
            } catch (SQLException e) {
                e.printStackTrace( );
            }
        }
        return null;
    }
}
相关推荐
哈基米喜欢哈哈哈4 分钟前
低版本的JVM遇到高版本的class字节码是否会报错
java·jvm
235167 分钟前
【并发编程】详解volatile
java·开发语言·jvm·分布式·后端·并发编程·原理
洛小豆34 分钟前
java 中 char 类型变量能不能储存一个中文的汉字,为什么?
java·后端·面试
爱吃烤鸡翅的酸菜鱼40 分钟前
从数据库直连到缓存预热:城市列表查询的性能优化全流程
java·数据库·后端·spring·个人开发
一只学java的小汉堡1 小时前
Java 面试高频题:HashMap 与 ConcurrentHashMap 深度解析(含 JDK1.8 优化与线程安全原理)
java·开发语言·面试
huohaiyu2 小时前
Hashtable,HashMap,ConcurrentHashMap之间的区别
java·开发语言·多线程·哈希
信奥卷王3 小时前
[GESP202503 五级] 原根判断
java·数据结构·算法
小咕聊编程3 小时前
【含文档+源码】基于SpringBoot的过滤协同算法之网上服装商城设计与实现
java·spring boot·后端
Zz_waiting.3 小时前
Spring 原理
java·spring·spring自动管理
瓯雅爱分享7 小时前
Java+Vue构建的采购招投标一体化管理系统,集成招标计划、投标审核、在线竞价、中标公示及合同跟踪功能,附完整源码,助力企业实现采购全流程自动化与规范化
java·mysql·vue·软件工程·源代码管理