jdbc连接数据库教程

第一步:准备好我们的源码

第二步:准备好MySQL(Linux,Windows,云端)

  1. 数据库的IP:
  2. 数据库的端口:
  3. 数据库的数据库名:
  4. 数据库的登录用户名
  5. 数据库的登录密码:
  6. 查看数据库的版本

第四步:准备好MySQL官网的jar包,包要与数据库版本一一对应

(SELECT @@VERSION;)//查看MySQL数据库版本

第五步:打开idea   建立以下包

这里的Student是个对象类,

Dao包是数据访问层;

Service包是业务逻辑层;

Controlier是展示层;

JDBC包放的是工具类,用来连接数据库;

Lib包放的是MySQL官网的jar包;

第六步:将准备好的jar包拖到lib包内:

如下:

然后右键点击它

点击蓝色的Add as Library

然后点击OK

第七步:

在until下建立一个工具类,类名自定义即可:

输入以下内容:

private static String url    = "jdbc:mysql://192.168.64.12*:3306/goods"; 

// 192.168.64.12*是IP3306是端口            IP和端口改成自己的

private static String dbName = "root";                               // 数据库用户名

    private static String dbPass = "123456";                          // 数据库密码

    public static Connection conn=null;

    public static PreparedStatement pstmt=null;

    public static ResultSet rs =null;

    public static Connection getConn() throws Exception{

        Class.forName("com.mysql.cj.jdbc.Driver");//加载驱动

        return DriverManager.getConnection(url,dbName,dbPass);

        //Class.forName("com.mysql.cj.jdbc.Driver");//加载驱动

        //return DriverManager.getConnection(url,dbName,dbPass);

        //这两句是固定的

    }

    public static void closeAll(Connection conn, PreparedStatement pstmt, ResultSet rs) throws Exception{//关流操作方法

        if(conn!=null)

            conn.close();

        if(pstmt!=null){

            pstmt.close();

        }

        if(rs!=null){

            rs.close();

        }

    }

第八步:创建对象类,将其他代码用分类分包的思想写入

(这里不会写入的自己加班加点想办法完成,本文档不管,上课讲的时候干鸡毛去了?一点也不尊重老师)

第九步:

分类分包思路:  对象类------dao包(数据访问层(增删改查))-------- Service包(业务逻辑层 写业务的比如登录验证啥的)------- Controlier(展示层(通常该类里面写的是连接网页的代码))

注:本文档这里Controlier以Java代码的形式使用!

Dao包内有两个文件

首先StudentDao很明显从图片上来看就知道它是一个接口,(注意:先建立接口然后再建接口实现类)

public interface StudentDao {//写所需要的方法
   
int studentAdd(Student std) throws Exception;
    void studentDel(ArrayList<Student> L) throws Exception;
    void studentChange(ArrayList<Student> L) throws Exception;
    void studentCheck() throws Exception;
}

然后StudentDaoimpl:

@Override

    public void studentAdd() throws Exception {

        List<Student> L=check();

        Scanner sc=new Scanner(System.in);

        String ID="";

        Student x;

        System.out.print("请输入学生学号:");

        String id=sc.next();

        for (int i = 0; i <L.size() ; i++) {

            x = L.get(i);

            ID = x.getId();

        }

        if(id.equals(ID)){

            System.out.println("学号已被使用,请重新输入");}

        else {

            Student x1=new Student();

            x1.setId(id);

            System.out.print("请输入学生姓名:");

            String name = sc.next();

            x1.setName(name);

            System.out.print("请输入学生年龄:");

            int age = sc.nextInt();

            x1.setAge(age);

            System.out.print("请输入学生生日:");

            String birth = sc.next();

            x1.setBirth(birth);

            String  sql="INSERT INTO Std VALUES(?,?,?,?)";

            String [] param={x1.getId(),x1.getName(),x1.getAge()+"",x1.getBirth()};

            Stdtool.executeUpdataSQL(sql,param);

        }

    }

    @Override

    public void studentDel() throws Exception {

        List<Student> L=check();

        Scanner sc=new Scanner(System.in);

        System.out.println("请输入要删除的学生学号:");

        String ID=sc.next();

        for (int i = 0; i <L.size() ; i++) {

            Student x2=L.get(i);

            String id=x2.getId();

            if(ID.equals(id)){

                String  sql="delete from Std where id="+id+"";

                //L.remove(i);

                Stdtool.executeUpdataSQL1(sql);

                System.out.println("删除成功!");

                break;

            }

            else{

                System.out.println("暂无信息!");

            }

        }

    }

    @Override

    public void studentChange() throws Exception {

        Scanner sc=new Scanner(System.in);

        List<Student> L=check();

        System.out.println("请输入要修改的学生学号");

        String ID=sc.next();

        for (int i = 0; i <L.size() ; i++) {

            Student x3=L.get(i);

            String id=x3.getId();

            if(id.equals(ID)){

                System.out.println("请输入新的姓名:");

                String name=sc.next();

                x3.setName(name);

                System.out.println("请输入新的年龄:");

                int age=sc.nextInt();

                x3.setAge(age);

                System.out.println("请输入新的生日:");

                String birth=sc.next();

                x3.setBirth(birth);

                String sql = "update Std set name = '"+x3.getName()+"',age = '"+x3.getAge()+

                        "',birth = '"+x3.getBirth()+"'where id = '"+id+"'";

                Stdtool.executeUpdataSQL1(sql);

                System.out.println("修改成功!");

            }

            else{

                System.out.println("暂无信息!");

            }

        }

    }

    @Override

    public void studentCheck() throws Exception {//查询全部学生信息

        String  sql="SELECT * from Std";

        Connection conn=Stdtool.getConn();

        PreparedStatement pstmt = conn.prepareStatement(sql);

        ResultSet rs=pstmt.executeQuery();

        List<Student> list =new ArrayList<>();

        while(rs.next()){

            Student std=new Student();

            std.setId(rs.getString(1));

            std.setName(rs.getString(2));

            std.setAge(rs.getInt(3));

            std.setBirth(rs.getString(4));

            list.add(std);

        }

        for(Student std:list){//遍历输出学生信息

            System.out.println(std);

        }

        Stdtool.closeAll(conn,pstmt,rs);

    }

    public List<Student> check() throws Exception{//通用方法

        String  sql="SELECT * from Std";

        Connection conn=Stdtool.getConn();

        PreparedStatement pstmt = conn.prepareStatement(sql);

        ResultSet rs=pstmt.executeQuery();

        List<Student> list =new ArrayList<>();

        while(rs.next()){

            Student std=new Student();

            std.setId(rs.getString(1));

            std.setName(rs.getString(2));

            std.setAge(rs.getInt(3));

            std.setBirth(rs.getString(4));

            list.add(std);

        }

        return list;

    }

这里的dao包下的代码如上可以复制粘贴使用

按照自己的需求进行修改即可

如果有问题可以咨询我

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值