使用JDBC操作数据库

本文介绍使用JDBC进行数据库操作的基本步骤,包括加载驱动、建立连接、执行SQL语句等,并通过具体示例展示了如何实现增删改查功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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);
	}
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值