日期:2014-05-20  浏览次数:21006 次

各位五湖四海的高手,请帮帮我,一个关于resultSet更新数据库的问题困扰了我2天
Java code
package gui;
import javax.swing.*;

import java.io.*;
import java.sql.*;
import java.util.Vector;

public class CategoryDA {
    private static ResultSet rs=null;
    private static Statement aStatement=null;
    private static Connection aConnection=null;
    static Vector Categories=new Vector();
    private static void getDBConnection()
    {
        try
        {
            Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
            aConnection=DriverManager.getConnection("jdbc:odbc:mydata","sa","sa");
        }catch(ClassNotFoundException e1)
        {
            JOptionPane.showMessageDialog(null, "驱动没找到,连接失败","Error",JOptionPane.ERROR_MESSAGE);
            
        }catch(SQLException e2)
        {
            JOptionPane.showMessageDialog(null, "用户名密码错误,连接失败","Error",JOptionPane.ERROR_MESSAGE);
            
        }
    }
    public static Vector getAll()
    {
        Vector <Category> Categories=new Vector();
        String strSQL;
        strSQL="SELECT * FROM Categories";
        try
        {
            getDBConnection();
            aStatement=aConnection.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_UPDATABLE);
            rs=aStatement.executeQuery(strSQL);
            while (rs.next())
            {
                Category aCategory=new Category();
                aCategory.setCategoryID(rs.getInt("CategoryID"));
                aCategory.setCategoryName(rs.getString("CategoryName"));
                aCategory.setDescription(rs.getString("Description"));
                byte [] buf1=rs.getBytes("Picture");
                aCategory.setPicture(buf1);
                
                Categories.add(aCategory);
            }
            rs.first();
        }
        catch(SQLException e)
        {
            JOptionPane.showMessageDialog(null, e.getMessage(),"Error",JOptionPane.ERROR_MESSAGE);
            
        }
        return Categories;
    }
    public static Category getCategory(ResultSet rs)
    {
        Category aCategory=new Category();
        try
        {
            aCategory.setCategoryID(rs.getInt("CategoryID"));
            aCategory.setCategoryName(rs.getString("CategoryName"));
            aCategory.setDescription(rs.getString("Description"));
            aCategory.setPicture(rs.getBytes("Picture"));
        }
        catch (SQLException e)
        {
            e.printStackTrace();
            JOptionPane.showMessageDialog(null, e.getMessage());
        }
        return aCategory;
    }
    public static Category GetCurrentCategory()
    {
        Category aCategory=new Category();
        try
        {
            rs.absolute(rs.getRow());
            aCategory=getCategory(rs);    
        }
        catch(SQLException e)
        {
            JOptionPane.showMessageDialog(null, e.getMessage(),"Error",JOptionPane.ERROR_MESSAGE);
        }
        return aCategory;
    }
    public static Category GetFirstCategory()
    {
        Category aCategory=new Category();
        try
        {
            rs.first();
            aCategory=getCategory(rs);
        } 
        catch(SQLException e)
        {
            JOptionPane.showMessageDialog(null, e.getMessage(),"Error",JOptionPane.ERROR_MESSAGE);
        }
        return aCategory;
    }
    public static Category GetNextCategory()
    {
        Category aCategory=new Category();
        try
        {
            if (rs.isLast())
            {
                JOptionPane.showMessageDialog(null, "已经是最后一条记录了","提示",JOptionPane.INFORMATION_MESSAGE);
                rs.absolute(rs.getRow());
            }
            else
            {
                rs.next();
                
            }
            aCategory=getCategory(rs);
        }catch(SQLException e)
        {
            JOptionPane.showMessageDialog(null, e.getMessage(),"Error",JOptionPane.ERROR_MESSAGE);
            
        }
        return aCategory;
    }
    public static Category getPrevCategory()
    {
        Category aCategory=new Category();
        try
        {
            if(rs.isFirst())
            {
                JOptionPane.showMessageDialog(null,"已经是第一条记录了","提示",JOptionPane.INFORMATION_MESSAGE);
            rs.absolute(rs.getRow());
            }
            else
            {
                rs.previous();
            }
            aCategory=getCategory(rs);
        }
        catch(SQLException e)
        {
            JOptionPane.showMessageDialog(null, e.getMessage(),"Error",JOptionPane.ERROR_MESSAGE);
            
        }
        return aCategory;
    }
    public static Category GetLastCategory()
    {
        Category aCategory=new Category();
        try
        {
            rs.last();
            aCategory=getCategory(rs);
        }
        catch(SQLException e)
        {
            JOptionPane.showMessageDialog(null, e.getMessage(),"Error",JOptionPane.ERROR_MESSAGE);
            
        }
        return aCategory;
    }
    public static void closeConneciton()
    {
        try
        {
            if(rs!=null)
            {
                rs.close();
            }
            if(aStatement!=null)
            {
                aStatement.close();
            }
            if(aConnection!=null&&!aConnection.isClosed())
            {
                aConnection.close();
            }
            
        }catch(SQLException e) 
        {
            JOptionPane.showMessageDialog(null, e.getMessage(),"Error",JOptionPane.ERROR_MESSAGE);
            
        }
        
    }
    public static void update (Category aCategory)
    {
        
        try
        {
            rs.updateString("CategoryName", aCategory.getCategoryName());
            rs.updateString("Description", aCategory.getDescription());
            rs.updateRow();
            
        }catch(SQLException e)
        {
            e.printStackTrace();
            JOptionPane.showMessageDialog(null, e.getMessage(),"Error",JOptionPane.ERROR_MESSAGE);
        }
    }
    public static void updatePhoto(byte[] buf)
    {
        
        try
        {
            rs.updateBytes("Picture", buf);
            rs.updateRow();
            JOptionPane.showMessageDialog(null, "修改成功","提示",JOptionPane.INFORMATION_MESSAGE);
            
            
        }catch(SQLException e)
        {
            JOptionPane.showMessageDialog(null, e.getMessage(),"Error",JOptionPane.ERROR_MESSAGE);
            
        }
    }
    public static void AddNew (Category aCategory)
    {
        try
        {
            rs.moveToInsertRow();
            rs.updateString("CategoryName", aCategory.getCategoryName());
            rs.updateString("Description", aCategory.getDescription());
            rs.insertRow();
            rs.last();
        }catch(SQLException e)
        {
            JOptionPane.showMessageDialog(null, e.getMessage());
        }
    }
    public static void delete()
    {
        try
        {
            rs.deleteRow();
            getAll();
        }catch(SQLException e)
        {
            JOptionPane.showMessageDialog(null, e.getMessage());
        }
    }
                       
}