问题是这样的:小弟先定义了一个DB_Operation类,然后在该类中定义了一个操作数据库的方法,源代码如下:
[code="java"]package com.chaliezhou.sms.service;
import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import com.chaliezhou.sms.conn.JDBC_Connections;
public class DB_Operations {
// 抽出添加数据的方法
public static void getOracleAddData() throws Exception{
String str = null;
String[] st = new String[6];
Connection conn = JDBC_Connections.getOracleConnection();
String sql = "{call PRO_STU_ADD(?,?,?,?,?,?)}";
CallableStatement cstmt = conn.prepareCall(sql);
cstmt.clearBatch();
try{
//将学号数据转整形
int i = Integer.parseInt(st[0]);
//将分数数据转浮点型
float f1 = Float.parseFloat(st[2]);
float f2 = Float.parseFloat(st[3]);
float f3 = Float.parseFloat(st[4]);
float f4 = (f1+f2+f3)/3;
cstmt.setInt(1,i);
cstmt.setString(2,st[1]);
cstmt.setFloat(3,f1);
cstmt.setFloat(4,f2);
cstmt.setFloat(5,f3);
cstmt.setFloat(6,f4);
//提交数据缓冲
cstmt.addBatch();
//提交数据
conn.commit();
System.out.println("数据插入成功!");
}catch(Exception ex){
ex.printStackTrace();
}
}[/code]
然后又定义了一个操作类用来从控制台接收数据,代码如下:
[code="java"]package com.chaliezhou.sms.view;
import java.sql.Connection;
import java.util.Scanner;
import com.chaliezhou.sms.conn.JDBC_Connections;
import com.chaliezhou.sms.service.DB_Operations;
public class Data_IO {
public static void main(String[] args) throws Exception {
Connection conn = JDBC_Connections.getOracleConnection();
Object ob = null;
String[] st = new String[6];
Scanner sc = new Scanner(System.in);
System.out.println("请输入学号:");
st[0] = sc.nextLine();
System.out.println("请输入姓名:");
st[1] = sc.nextLine();
System.out.println("请输入语文分数:");
st[2] = sc.nextLine();
System.out.println("请输入数学分数:");
st[3] = sc.nextLine();
System.out.println("请输入英语分数:");
st[4] = sc.nextLine();
[color=darkred] getOracleAddData();[/color]
}
}[/code]
请问怎样在这个操作类中调用方法呢?我在这里写了getOracleAddData()(红字所示),但提示出错。正确的写法应该是怎样呢?