对象关系映射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;
    }
}
相关推荐
小北方城市网1 小时前
Redis 分布式锁高可用实现:从原理到生产级落地
java·前端·javascript·spring boot·redis·分布式·wpf
六义义1 小时前
java基础十二
java·数据结构·算法
毕设源码-钟学长2 小时前
【开题答辩全过程】以 基于SpringBoot的智能书城推荐系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
笨手笨脚の3 小时前
深入理解 Java 虚拟机-03 垃圾收集
java·jvm·垃圾回收·标记清除·标记复制·标记整理
莫问前路漫漫3 小时前
WinMerge v2.16.41 中文绿色版深度解析:文件对比与合并的全能工具
java·开发语言·python·jdk·ai编程
九皇叔叔3 小时前
【03】SpringBoot3 MybatisPlus BaseMapper 源码分析
java·开发语言·mybatis·mybatis plus
挖矿大亨3 小时前
c++中的函数模版
java·c++·算法
a程序小傲4 小时前
得物Java面试被问:RocketMQ的消息轨迹追踪实现
java·linux·spring·面试·职场和发展·rocketmq·java-rocketmq
青春男大4 小时前
Redis和RedisTemplate快速上手
java·数据库·redis·后端·spring·缓存
Ghost Face...4 小时前
i386 CPU页式存储管理深度解析
java·linux·服务器