码迷,mamicode.com
首页 > 数据库 > 详细

java连接Oracle数据库实现增删改查并在Navicat中显示

时间:2018-07-15 13:01:24      阅读:323      评论:0      收藏:0      [点我收藏+]

标签:add   连接数据库   插入   sele   select   jdbc   void   public   runtime   

创建TEST表

技术分享图片

eclipse中的java项目

技术分享图片

 

代码

数据库方法类 DBUtil:

package util;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class DBUtil {

 // 创建一个数据库连接
    public static Connection getConnection() 
    {
        Connection connection = null;
    	 String USERNAMR = "system";
         String PASSWORD = "*****";//自己的密码
         String DRVIER = "oracle.jdbc.OracleDriver";
         String URL = "jdbc:oracle:thin:@localhost:1521:orcl";
        try {
            Class.forName(DRVIER);
            connection = DriverManager.getConnection(URL, USERNAMR, PASSWORD);
            System.out.println("成功连接数据库");
        } catch (ClassNotFoundException e) {
            throw new RuntimeException(e);
        } catch (SQLException e) {
            throw new RuntimeException(e);
        }
 
        return connection;
    }
    //关闭资源
    public static void close(Connection connection ) {
		try {
			if (connection != null) {
				connection.close();
			}
			
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
	public static void close(PreparedStatement preparedStatement ) {
		try {
			if (preparedStatement != null) {
				preparedStatement.close();
			}
			
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
	public static void close(ResultSet resultSet ) {
		try {
			if (resultSet != null) {
				resultSet.close();
			}
			
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}

}

实体类 Model

package test;

public class Model {
    private String id;

    private String username;
    private String password;
    private String name;
    private int age;

    public String getId() {
        return id;
    }
    public void setId(String id) {
        this.id = id;
    }
    public Model()
    {
        
    }
    public Model(String id, String username, String password, String name, int age) {
        super();
        this.id = id;
        this.username = username;
        this.password = password;
        this.name = name;
        this.age = age;
    }
    public void update(String username, String password, String name, int age) {
        this.username = username;
        this.password = password;
        this.name = name;
        this.age = age;
    }
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
}

测试类 Test

package test;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;


import util.DBUtil;

public class Test {
    public void add(Model model)//添加数据
    {
        Connection connection=DBUtil.getConnection();
        String sql="insert into test(id,username,password,name,age)values(?,?,?,?,?)";
        PreparedStatement preparedStatement = null;
        try {
            preparedStatement = connection.prepareStatement(sql);
            preparedStatement.setString(1, model.getId());
            preparedStatement.setString(2, model.getUsername());
            preparedStatement.setString(3, model.getPassword());
            preparedStatement.setString(4, model.getName());
            preparedStatement.setInt(5, model.getAge());
            preparedStatement.executeUpdate();
            System.out.println("插入成功");
        } catch (SQLException e) {
            // TODO 自动生成的 catch 块
            e.printStackTrace();
        }finally{
            DBUtil.close(preparedStatement);
            DBUtil.close(connection);
        }
    }
    public void update(Model model)//修改数据
    {
        Connection connection=DBUtil.getConnection();
        String sql="update test set username=?,password=?,name=?,age=?";
        PreparedStatement preparedStatement = null;
        try {
            preparedStatement = connection.prepareStatement(sql);
            preparedStatement.setString(1, model.getUsername());
            preparedStatement.setString(2, model.getPassword());
            preparedStatement.setString(3, model.getName());
            preparedStatement.setInt(4, model.getAge());
            preparedStatement.executeUpdate();
        } catch (SQLException e) {
            // TODO 自动生成的 catch 块
            e.printStackTrace();
        }finally{
            DBUtil.close(preparedStatement);
            DBUtil.close(connection);
        }
        
    }
    public Model load(String id) //查询数据
    {
        Connection connection = DBUtil.getConnection();
        //准备sql语句
        String sql = "select * from test  where id = ?";
        //创建语句传输对象
        PreparedStatement preparedStatement = null;
        ResultSet resultSet = null;
        Model model = null;
        try {
            preparedStatement = connection.prepareStatement(sql);
            preparedStatement.setString(1, id);
            resultSet = preparedStatement.executeQuery();
            while(resultSet.next()) {
                model = new Model();
                model.setId(id);
                model.setUsername(resultSet.getString("username"));
                model.setPassword(resultSet.getString("password"));
                model.setName(resultSet.getString("name"));
                model.setAge(resultSet.getInt("age"));
            }
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }finally {
            DBUtil.close(resultSet);
            DBUtil.close(preparedStatement);
            DBUtil.close(connection);
        }
        return  model;
    }
    public void delete(String id)//删除数据
    {
        Connection connection=DBUtil.getConnection();
        String sql="delete from test where id=?";
        PreparedStatement preparedStatement=null;
        try {
            preparedStatement=connection.prepareStatement(sql);
            preparedStatement.setString(1,id);
            preparedStatement.executeQuery();
            System.out.println("删除成功");
        } catch (SQLException e) {
            // TODO 自动生成的 catch 块
            e.printStackTrace();
        }finally {
            DBUtil.close(preparedStatement);
            DBUtil.close(connection);
        }
        
    }
    
    public static void main(String args[])
    {
        Test test=new Test();
        Model model=new Model("1","123","123","张三",18);
//        test.add(model);
        
        
//        model.update("123","123","张三",28);
//        test.update(model);
//        
//        model=test.load("1");
//        System.out.println("查询结果————姓名:"+model.getName()+",年龄:"+model.getAge());
//        
        test.delete("1");
    }
}

用Navicat连接Oracle数据库,因为创建的表自动存放在SYSTEM表空间内,在SYSTEM下边可以直接找到。

技术分享图片

 

技术分享图片

 

Navicat中的数据变化:

插入数据。

技术分享图片

更改后的数据。

技术分享图片

删除数据。

技术分享图片

 

java连接Oracle数据库实现增删改查并在Navicat中显示

标签:add   连接数据库   插入   sele   select   jdbc   void   public   runtime   

原文地址:https://www.cnblogs.com/ssyh/p/9313225.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!