一个关于jdbc操作mysql和java基础练手的通讯录管理系统小项目

首先 : 整个项目的项目结构为 :

1.第一步先导入数据库的驱动,我的mysql数据库是8.0以上版本,然后导入的驱动就是8.0.16版本的jar包;

1.JdbcBase :

JDBC基础操作封装成了JdbcBase类,在里面先静态定义了数据库连接对象和DQL查询结果,然后在静态代码块中加载了mysql的驱动,创建了连接对象,创建了执行查询的sql语句,和执行增删改查的sql语句,在输入的参数中用Object[]来接收'?'占位符的实际参数;最后再释放资源;

代码 :

java 复制代码
package com.it.dao;

import java.sql.*;

public class JdbcBase {
    static Connection conn;// 数据库连接对象
    static ResultSet rs;// DQL查询结果

    // 在静态代码块中加载驱动
    static {
        try{
            Class.forName("com.mysql.cj.jdbc.Driver");
        } catch (ClassNotFoundException e){
            e.printStackTrace();
        }
    }

    //创建连接对象
    public static Connection getConnection() {
        try {
            conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/pcm?characterEncoding=utf8&serverTimezone=GMT%2B8","root","1234");
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return conn;
    }

    //创建执行查询的sql语句
    public static ResultSet querySql(String sql, Object[] obj)throws Exception{
        // 获取连接对象
        conn = getConnection();
        // 获取执行sql语句对象
        try {
            PreparedStatement pstm = conn.prepareStatement(sql);
            if(obj != null){
                for(int  i=0;i<obj.length;i++){
                    pstm.setObject(i+1,obj[i]);
                }
            }
            rs = pstm.executeQuery();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return rs;
    }

    // 执行增删改sql语句
    public static int updateSql(String sql,Object[] obj){// 返回1成功,返回0失败
        int num = 0;
        // 获取连接对象
        conn = getConnection();
        // 获取执行sql语句的对象
        try {
            PreparedStatement pstm = conn.prepareStatement(sql);
            if(obj !=  null){
                // 对 ? 进行赋值
                for(int i=0;i<obj.length;i++){
                    pstm.setObject(i+1,obj[i]);
                }
            }
            //执行增删改语句
            num = pstm.executeUpdate();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return num;

    }
    // 释放资源
    public static void close(){
        try {
            conn.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

2.App.java :

编写主界面 : 就是一些简单但又繁杂的部分;大概截图如下 :

然后在下面编写了上面方法的实现;

3.pcm.java

登录之后,进入个人的通讯录管理系统;

4.UserDao和ContactDao部分 :

定义了一些增删改查的部分代码 :

如 :

数据库部分 :

包含两张表 user表 和 Contact 表 :

数据库结构如 :

user表和contact表通过id和id_user来连接,contact表中的id_user标识该联系人属于那个user;

项目的一些运行截图 :

相关推荐
IvorySQL6 小时前
PostgreSQL 技术日报 (3月9日)|EXPLAIN ANALYZE 计时优化与复制语法讨论
数据库·postgresql·开源
stark张宇10 小时前
MySQL 核心内幕:从索引原理、字段选型到日志机制与外键约束,一篇打通数据库任督二脉
数据库·mysql·架构
倔强的石头_10 小时前
融合数据库架构实践:关系型、JSON与全文检索的“一库多能”深度解析
数据库
星辰员12 小时前
KingbaseES数据库:ksql 命令行用户与权限全攻略,从创建到删除
数据库
华仔啊1 天前
千万别给数据库字段加默认值 null!真的会出问题
java·数据库·后端
随风飘的云2 天前
MySQL的慢查询优化解决思路
数据库
IvorySQL2 天前
PostgreSQL 技术日报 (3月7日)|生态更新与内核性能讨论
数据库·postgresql·开源
赵渝强老师2 天前
【赵渝强老师】金仓数据库的数据文件
数据库·国产数据库·kingbase·金仓数据库
随逸1772 天前
《Milvus向量数据库从入门到实战,手把手搭建语义检索系统》
数据库
神秘的猪头3 天前
🚀 React 开发者进阶:RAG 核心——手把手带你玩转 Milvus 向量数据库
数据库·后端·llm