JDBC

1. 什么是JDBC 

JDBC(Java Database Connection),sun公司为开发者使用数据库提供的一组编程接口,再由各大数据库厂商来实现编程类(JDBC驱动程序)

2. JDBC访问数据库流程

  • 加载驱动

装载MySql驱动:Class.ForName("com.mysql.jdbc.Driver");

驱动程序内部是Socket来实现业务

  • 建立连接

建立MySql数据库连接:DriverManager.getConnection("jdbc:mysql://localhost:3306/数据库名", "账号", "密码");

此处连接的是本地数据库,若要连接其他的数据库,则把localhost改成IP地址,如果mysql没做改动的话,默认是使用3306端口

DriverManager是Sun公司的一个接口,由厂商实现。

Java和数据库通过Socket来实现通信,是一个远程连接。比较耗时!

  • 发送SQL查询

1. 使用Statement

    execute()

    executeQuery():用于select查询语句,查询到可以获得一个返回集

    executeUpdate():用于insert、delete、update,返回成功执行的条数

    因为statement在使用的时候sql语句中含有变量时,需采用拼字符串的方式,所有有可能出现sql注入的风险

2. 使用PreparedStatement

String sql = "insert into t_user (username, pwd, regTime) values(?, ?, ?)"; // 变量使用?作为占位符

PreparedStatement ps = conn.preparedStatement(sql);

ps.setObject(1, "Sam"); // 偏移地址从1开始,使用setObject可以不用区分要插入的对象类型,系统自动转换

ps.execute(); 执行

  • 得到查询结果

ResultSet rs = stmt.executeQuery();

使用while循环去读取结果,返回结果集默认指向第一个数据之前,next()方法将指针下移一个,若存在数据则返回真,此时rs.getString(x),rs.getInt(x)等方法可以读取改行数据,x指向当前行的第x列,取出来的数据类型需和方法名对应。若不存在下一条数据则返回假。

while(rs.next())

{

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值