JCBC(Java Data Base Connection)连接数据库实现增删改查

Connection conn = null;

PreparedStatement ps = null;

ResultSet rs = null;

  1. 注册驱动

Class.forName("com.mysql.jdbc.Driver");

调用类方法forName注册驱动,方法参数为jdbc驱动文件名,驱动文件可在在各大数据库厂商官网下载

  1. 获取数据库连接对象

conn = DriverManager.getConnection(url);

url:统一资源定位标志

常见数据库url格式:

  • Microsoft SQL Server 2005 JDBC Driver

jdbc:sqlserver://<server_name>:<port>默认端口1433,如果服务器使用默认端口则port可以省略

  • Oracle:

jdbc:oracle:thin:@//<host>:<port>/ServiceName或jdbc:oracle:thin:@<host>:<port>:<SID>

  • MySql:

jdbc:mysql://<host>:<port>/<database_name>默认端口3306,如果服务器使用默认端口则port可以省略MySQL Connector/J Driver 允许在URL中添加额外的连接属性jdbc:mysql://<host>:<port>/<database_name>?property1=value1&property2=value2

3. 编写SQL(以查询为例)

String sql = "insert into t_user(userId,userName,passWord) values(4,?,?)";

SQL 语句中增删改查条件参数用问号(?)来表示(?在SQL中表示占位符)

4. 获取预编译的数据库操作对象

ps = conn.prepareStatement(sql);

预编译相当于将不含参数的sql语句预先编译一遍,再将参数传入,防止sql注入导致的漏洞

5.将占位符处的参数传送给已经预编译好了的sql语句,

  ps.setString(1,"xxxx");

ps.setString(2, "xxxx");

第一个参数是占位符的g编号,编号从1开始数,第二个参数数据类型是String,是出入占位符处的参数,常用的传参函数有:

PreparedStatement类型的对象ps的传参方法有

void setInt(int parameterIndex, int x)

void setLong(int parameterIndex, long x)

void setString(int parameterIndex, String x)

void setBlob (int parameterIndex, Blob x)

void setDate(int parameterIndex, java.sql.Date x, Calendar cal)

6.执行SQL语句 查询sql语句执行的返回类型是结果集,增删改sql语句的返回结果是影响行数

  • 增删改:

count = ps.executeUpdate();

  • 查询:

rs = ps.executeQuery(); //返回查询结果集

7.按照指定格式输出查询结果

while(rs.next()){

int userId = rs.getInt("userId");

String userName = rs.getString("userName");

String passWord = rs.getString("passWord");

System.out.println(userId+"\t"+userName+"\t"+passWord);

}

结果集有个游标,一开始指向结果集第一行的前面

next()函数将游标指向下一行,返回游标,若为空,返回0

获取数据函数:

getString("列名")

getInt("列名")

注:记得释放对象资源

参考代码:

Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;

try{
    //注册驱动    调用类方法forName注册驱动,方法参数为jdbc驱动文件名,驱动文件可在在各大数据库厂商官网下载
    Class.forName("com.mysql.jdbc.Driver");
    // 获取数据库连接对象        参数为URL
    conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb?characterEncoding=UTF-8","root","123123");           
    // 编写查询 SQL            SQL 语句中的参数用问号(?)来表示(?在SQL中表示占位符)
    String sql = "insert into t_user(userId,userName,passWord) values(4,?,?)";
    // 获取预编译的数据库操作对象        预编译相当于将不含参数的sql语句预先编译一遍,再将参数传入,防止sql注入导致的漏洞
    ps = conn.prepareStatement(sql);
    /*将占位符处的参数传送给已经预编译好了的sql语句,
    第一个参数是第一个占位符,个数从1开始数,第二个参数数据类型是String,是出入占位符处的参数
    PreparedStatement类型的对象ps的传参方法有
    void setInt(int parameterIndex, int x)
    void setLong(int parameterIndex, long x)
    void setString(int parameterIndex, String x)
    void setBlob (int parameterIndex, Blob x)
    void setDate(int parameterIndex, java.sql.Date x, Calendar cal)
    */
    
    ps.setString(1,"xxxx");
    ps.setString(2, "xxxx");
    //执行SQL语句 查询sql语句执行的返回类型是结果集,增删改sql语句的返回结果是影响行数
    count = ps.executeUpdate();
    
}catch(Exception e){
    //抛出异常
    e.printStackTrace();
}finally{
    // 关闭资源,注意关闭资源的顺序
    try{
        if(ps != null){
            ps.close();
        }
        if(conn != null){
            conn.close();
        }
    }catch(Exception e){
        e.printStackTrace();
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值