JDBC系列教材 (九)- 使用JDBC做一个ORM例子

本文介绍了如何在Java中使用ORM(Object-RelationalMapping)技术,通过JDBC连接MySQL数据库,根据ID查询Hero对象并返回。展示了get方法和相关代码实例。

ORM=Object Relationship Database Mapping

对象和关系数据库的映射

简单说,一个对象,对应数据库里的一条记录

步骤1:根据id返回一个Hero对象
步骤2:练习-ORM
步骤3:答案-ORM

步骤 1 : 根据id返回一个Hero对象

提供方法get(int id)
返回一个Hero对象

package charactor;

public class Hero {

    //增加id属性

    public int id;

    public String name;

    public float hp;

    public int damage;

}

package jdbc;

   

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;

  

import charactor.Hero;

   

public class TestJDBC {

   

    public static Hero get(int id) {

        Hero hero = null;

        try {

            Class.forName("com.mysql.jdbc.Driver");

        catch (ClassNotFoundException e) {

            e.printStackTrace();

        }

        try (Connection c = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/how2java?characterEncoding=UTF-8","root""admin");

            Statement s = c.createStatement();) {

            String sql = "select * from hero where id = " + id;

   

            ResultSet rs = s.executeQuery(sql);

   

            // 因为id是唯一的,ResultSet最多只能有一条记录

            // 所以使用if代替while

            if (rs.next()) {

                hero = new Hero();

                String name = rs.getString(2);

                float hp = rs.getFloat("hp");

                int damage = rs.getInt(4);

                hero.name = name;

                hero.hp = hp;

                hero.damage = damage;

                hero.id = id;

            }

   

        catch (SQLException e) {

            // TODO Auto-generated catch block

            e.printStackTrace();

        }

        return hero;

   

    }

   

    public static void main(String[] args) {

           

        Hero h = get(22);

        System.out.println(h.name);

   

    }

}


更多内容,点击了解: https://how2j.cn/k/jdbc/jdbc-orm/391.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值