使用JDBC操作数据库

来源:互联网 发布:dota2无法连接网络 编辑:程序博客网 时间:2024/06/05 14:31

JDBC操作数据库步骤:

1.加载驱动类
Class.forName()方法将指定类加载到Java虚拟机中
2.建立与数据库的链接
DriverManager.getConnection(URL,LOGINID,LOGINPWD);方法获取与数据库的链接
URL:数据连接字符串
LOGINID:用户名
LOGINPWD:用户密码
3.创建操作对象
可以使用Statement,Preparedstatement操作对象
4.关闭数据库的链接


Statement 操作对象
public abstract class BaseDao {private final static String DRIVER="com.microsoft.sqlserver.jdbc.SQLServerDriver";  private final static String URL = "jdbc:sqlserver://localhost:1433;databasename=shopdb";private final static String LOGINID = "sa";private final static String LOGINPWD = "123456";public Connection openConnection() throws Exception{Class.forName(BaseDao.DRIVER); //加载驱动类Connection conn = DriverManager.getConnection(BaseDao.URL,BaseDao.LOGINID,BaseDao.LOGINPWD);//使用DriverManager类调用getConnection()方法建立与数据库的链接return conn; }//关闭数据库连接public void closeConn(Connection conn,Statement st,ResultSet rs) throws Exception{if(rs!=null){rs.close();}if(st!=null){st.close();}if(conn!=null){conn.close();}}//方法的重载public void closeConn(Connection conn,Statement st) throws Exception{closeConn(conn,st,null);}//对数据库进行增删改操作public int executeSql(String sql) throws Exception{Connection conn = openConnection(); //打开数据库连接Statement st = conn.createStatement();//使用Statement创建操作对象 注意Statement在对Sql语句操作时时先非预先编译的int cnt = st.executeUpdate(sql);     //返回受影响的行数closeConn(conn,st);//关闭连接return cnt;}}
public class ProductDao extends BaseDao{public void add() throws Exception{  //向数据库增加记录String sql = "insert into tbproduct values('鸭腿','根',5,'煌上煌','武汉')";//Statement操作数据库可以直接在sql语句中添加数据super.executeSql(sql);//调用父类的方法}public void update() throws Exception{//修改数据库的数据String sql = "update tbproduct set gname='皮蛋' ,unit='个',price='1',brand='仙丹',place='武汉' where gid=13 ";super.executeSql(sql);}public void delete() throws Exception{String sql = "delete tbproduct where gid=14";super.executeSql(sql);}public void search() throws Exception{//查询数据库的内容
Connection conn = super.openConnection();String sql = "select * from tbproduct";Statement st = conn.createStatement();ResultSet rs = st.executeQuery(sql);//查询返回的是结果集System.out.println("商品名称"+"\t"+"商品单位"+"\t"+"商品单价"+"\t"+"商品品牌"+"\t"+"商品产地");while(rs.next()){System.out.println(rs.getString("gname")+"\t"+rs.getString("unit")+"\t"+rs.getFloat("price")+"\t"+rs.getString("brand")+"\t"+rs.getString("place"));}super.closeConn(conn, st, rs);}}



原创粉丝点击