JDBC西八

JDBC

–1.概述

  • 什么是JDBC:一种专门用来 通过java程序操作数据库的标准
  • 在这里插入图片描述
使用步骤
  • 导入jar包
  • 获取数据库的链接(用户名,密码)
  • 通过执行SQL语句
  • 执行获取结果集
  • ==========================================
  • 1.注册驱动
  • 2.获取数据库的链接
  • 3.获取传输器,执行SQL
  • 4.执行SQL语句
  • 5.解析结果集
    在这里插入图片描述

常规的连接数据库执行SQl语句

import java.sql.*;

//测试 jdbc
//需求:查询cgb2104库里的students表里的所有数据
public class Test1 {
    public static void main(String[] args) throws Exception {
        //1,注册驱动
        Class.forName("com.mysql.cj.jdbc.Driver");
        //2,获取和数据库的连接
//String url= "jdbc:mysql://localhost:3306/cgb2104?characterEncoding=utf8";//指定要连接哪个数据库
//        String url= "jdbc:mysql:///db3?characterEncoding=utf8";//指定要连接哪个数据库
        String url = "jdbc:mysql://localhost:3306/db3?characterEncoding = utf-8";
        String user= "root" ; //使用的用户名
        String pwd= "root" ; //使用的密码
        Connection conn = DriverManager.getConnection(url, user, pwd);
        //3,获取传输器,执行SQL
        Statement st = conn.createStatement();
        //4,执行SQL
        ResultSet rs = st.executeQuery("select * from students");
        //        int len = st.executeUpdate("insert into user2 values(2,'sd','sad')"); 往里边插入数据的方法
        //5,解析结果集
        while( rs.next() ){//next()判断结果集中是否有数据
            for (int i = 1; i <= 5 ; i++) {
                //获取每列的值并打印
                System.out.println( rs.getString(i) );                  //返回对应索引的数据
                System.out.println(rs.getString("sname"));   //返回对应列的值
            }
        }
        //6,释放资源
        rs.close(); //关闭结果集
        st.close();//关闭传输器
        conn.close();//关闭连接
    }
}


解决上边的SQL冲突问题

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.Collection;
import java.util.Scanner;

/**
 * 解决SQL冲突的方法
 */
public class Test4 {
    public static void main(String[] args) throws Exception {
        Class.forName("com.mysql.cj.jdbc.Driver");
        String url = "jdbc:mysql://localhost:3306/db3?characterEncoding = utf-8";
        Connection con = DriverManager.getConnection(url,"root","root");
        System.out.println("请输入用户名");
        String user = new Scanner(System.in).nextLine();
        System.out.println("请输入用户名");
        String pwd = new Scanner(System.in).nextLine();

        //要执行的SQL语句
        String sql = "select * from user2 where name = ? and password = ?";
        //把SQL语句发给传输器来运行
        PreparedStatement ps = con.prepareStatement(sql);
        //给SQL里边设置参数
        ps.setString(1,user);
        ps.setString(2,pwd);

        ResultSet rs = ps.executeQuery();
        if(rs.next()){
            for(int i =1;i<2;i++){
                System.out.println(rs.getString(i));
            }
            System.out.println("登录成功");
        }else{
            System.out.println("登录失败");
        }
        ps.close();
        con.close();

    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值