Java通讯录管理系统

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 使用DAO分层设计模式设计了通讯管理系统使用了c3p0地址池和dbutils,没有写前端,连接的是mysql数据库,不涉及到太多的技术,仅供入门JDBC的小伙伴参考一下

Java通讯录管理系统

  • 使用DAO分层设计模式设计了通讯管理系统
  • 使用了c3p0地址池和dbutils,没有写前端,连接的是mysql数据库,不涉及到太多的技术,仅供入门JDBC的小伙伴参考一下.

简介

其中写的类和文件先简单介绍一下:

c3p0-config.xml c3p0地址池配置文件
com.test.Utils 地址池连接工具类
com.test.CreateAddress 对mysql中的test数据库创建test表
com.test.AddressListTest 通讯录操作主方法
com.javabean.AddressList 通讯录实体类
com.dao.AddressHandle 通讯录定义规则
com.dao.impl.AddressHandleimpl 通讯录操作具体实现

使用到的jar包

在这里插入图片描述

c3p0配置文件

命名一定要是c3p0-config.xml.

<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config>
    <default-config>
        <property name="driverClass">com.mysql.jdbc.Driver</property>
        <property name="jdbcUrl">jdbc:mysql://localhost:3306/test</property>
        <property name="user">root</property>
        <property name="password">root1</property>
        
        <property name="initialPoolSize">5</property>
        <property name="maxPoolSize">10</property>
        <property name="checkoutTimeout">2000</property>
        <property name="maxIdleTime">1000</property>
    </default-config>>
</c3p0-config>

C3p0连接池工具类

package com.test;
/**
 * 生成c3p0连接池的工具类
 * getConnection()获取默认数据的连接
 * getDataSource()获取默认的数据源
 */
import java.sql.Connection;
import java.sql.SQLException;
import javax.sql.DataSource;
import com.mchange.v2.c3p0.ComboPooledDataSource;

public class Utils {
    public static DataSource ds = new ComboPooledDataSource();
    
    public static Connection getConnection() {
        Connection c = null;
        try {
            c = ds.getConnection();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return c;
    }
    
    public static DataSource getDataSource() {
        return ds;
    }
}

创建test数据库中的test表

package com.test;

import java.sql.SQLException;
import org.apache.commons.dbutils.QueryRunner;

/**
 * 用于生成默认配置(test)数据库中的一个表(test)
 */
public class CreateAddress {
    public static void main(String[] args) {
        QueryRunner qr = new QueryRunner(Utils.getDataSource());
        
        String sql = "create table test("
                + "name varchar(10) primary key,"
                + "workUnit varchar(255),"
                + "num char(11) not null,"
                + "e_mail varchar(32)"
                + ");";
        try {
            qr.update(sql);
        } catch (SQLException e) {
            e.printStackTrace();
        }
        System.out.println("test表创建成功");
    }
}

书写通讯实体类

可以实现序列化接口,这里我没有实现,但不影响使用

package com.javabean;
/**
 * 通讯录类
 */
public class AddressList {
    private String name;
    private String workUnit;
    private String num;
    private String e_mail;
    
    public AddressList() {
        super();
    }

    public AddressList(String name, String workUnit, String num, String e_mail) {
        super();
        this.name = name;
        this.workUnit = workUnit;
        this.num = num;
        this.e_mail = e_mail;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getWorkUnit() {
        return workUnit;
    }

    public void setWorkUnit(String workUnit) {
        this.workUnit = workUnit;
    }

    public String getNum() {
        return num;
    }

    public void setNum(String num) {
        this.num = num;
    }

    public String getE_mail() {
        return e_mail;
    }

    public void setE_mail(String e_mail) {
        this.e_mail = e_mail;
    }

    @Override
    public String toString() {
        return "AddressList [name=" + name + ", workUnit=" + workUnit + ", num=" + num + ", e_mail=" + e_mail + "]";
    }
    
}

定义通讯录管理系统规则

package com.dao;

import com.javabean.AddressList;

public interface AddressHandle {
    
    public abstract void add(String s1,String s2,String s3,String s4);
    
    public abstract void remove(String s1);
    
    public abstract void update(String s1,String s2,String s3);
    
    public abstract AddressList select(String name);
    
    public abstract AddressList selectnum(String name);
    
    public abstract void show();
    
}

通讯录管理系统规则接口的实现类

package com.dao.impl;

import java.sql.SQLException;
import java.util.List;

import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;

import com.dao.AddressHandle;
import com.javabean.AddressList;
import com.test.Utils;

public class AddressHandleimpl implements AddressHandle {

    @Override
    public void add(String s1, String s2, String s3, String s4) {
        AddressList add = select(s1);
        if (add != null) {
            System.out.println("您存在此联系人,您可能需要修改业务");
        } else {
            QueryRunner qr = new QueryRunner(Utils.getDataSource());

            String sql = "insert into test values (?,?,?,?)";

            int update = 0;
            try {
                update = qr.update(sql, s1, s2, s3, s4);
            } catch (SQLException e) {
                e.printStackTrace();
            }
            if (update > 0) {
                System.out.println("插入成功");
            } else {
                System.out.println("插入失败,可能的原因是您输入的内容不合法,无法帮您存进数据库");
                System.out.println("友情提示:手机号最多11位");
                System.out.println("友情提示:姓名最多10个字符");
            }
        }

    }

    @Override
    public void remove(String s1) {
        AddressList add = select(s1);
        if (add == null) {
            System.out.println("此联系人不存在,无法进行删除修改,您可能需要别的功能");
        } else {
            QueryRunner qr = new QueryRunner(Utils.getDataSource());
            int update = 0;

            String sql = "delete from test where name=?";

            try {
                update = qr.update(sql, s1);
            } catch (SQLException e) {
                e.printStackTrace();
            }
            
            if (update > 0) {
                System.out.println("删除成功");
            } else {
                System.out.println("删除失败,可能的原因是您输入的内容不合法,无法帮您删除");
            }
        }

    }

    @Override
    public void update(String s1, String s2, String s3) {
        AddressList add = select(s1);
        if (add == null) {
            System.out.println("此联系人不存在,无法进行修改,您可能需要插入功能");
        } else {
            QueryRunner qr = new QueryRunner(Utils.getDataSource());
            int update = 0;

            String sql = "update test set name=?,workUnit=?,num=?,e_mail=? where name=?";

            if ("a".equalsIgnoreCase(s2)) {
                try {
                    update = qr.update(sql, s3, add.getWorkUnit(), add.getNum(), add.getE_mail(), s1);
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }  else if ("b".equalsIgnoreCase(s2)) {
                try {
                    update = qr.update(sql, add.getName(), add.getWorkUnit(), s3, add.getE_mail(), s1);
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }  else {
                System.out.println("您输入要修改的选项有误");
            }

            if (update > 0) {
                System.out.println("更新成功");
            } else {
                System.out.println("更新失败,可能的原因是您输入的内容不合法,无法帮您更新进数据库");
            }
        }

    }

    @Override
    public AddressList select(String name) {

        QueryRunner qr = new QueryRunner(Utils.getDataSource());

        String sql = "select * from test where name = ?";

        AddressList add = null;
        try {

            add = qr.query(sql, new BeanHandler<>(AddressList.class), name);
        } catch (SQLException e) {
            e.printStackTrace();
        }

        return add;

    }

    @Override
    public void show() {
        QueryRunner qr = new QueryRunner(Utils.getDataSource());

        String sql = "select * from test";

        List<AddressList> list = null;
        try {
            list = qr.query(sql, new BeanListHandler<>(AddressList.class));
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        int count = 0;

        for (AddressList address : list) {
            System.out.println(address);
            count++;
        }
        System.out.println("查询到了" + count + "条记录");
    }

    @Override
    public AddressList selectnum(String name) {
        QueryRunner qr = new QueryRunner(Utils.getDataSource());

        String sql = "select * from test where num = ?";

        AddressList add = null;
        try {

            add = qr.query(sql, new BeanHandler<>(AddressList.class), name);
        } catch (SQLException e) {
            e.printStackTrace();
        }

        return add;
    }

}

操作通讯录管理系统的main方法

package com.test;

import java.util.Scanner;

import com.dao.impl.AddressHandleimpl;
import com.javabean.AddressList;

public class AddressListTest {
    public static void main(String[] args) {
        AddressHandleimpl address = new AddressHandleimpl();
        Scanner sc = new Scanner(System.in);
        while (true) {
            System.out.println("[A]插入 [B]修改 [C]删除 [D]显示 [E] 根据名字查询 [F]根据手机号查询[G]退出");
            System.out.println("请输入您的选择,不区分大小写");
            String str1 = sc.nextLine();

            if ("a".equalsIgnoreCase(str1)) {// 插入
                System.out.println("请输入您要插入的名字");
                String name1 = sc.nextLine();
                System.out.println("请输入您要插入的工作单位");
                String name2 = sc.nextLine();
                System.out.println("请输入您要插入的电话号码");
                String name3 = sc.nextLine();
                System.out.println("请输入您要插入的电子邮箱");
                String name4 = sc.nextLine();

                address.add(name1, name2, name3, name4);

            } else if ("b".equalsIgnoreCase(str1)) {// 修改

                System.out.println("请输入您要修改的联系人的姓名是?");
                String name1 = sc.nextLine();

                System.out.println("[A]姓名[B]电话号码");
                System.out.println("请输入您要修改的选项,必须是A B中的一个,否则会报错");
                String name2 = sc.nextLine();
                System.out.println("请您输入修改后的值");
                String name3 = sc.nextLine();

                address.update(name1, name2, name3);

            } else if ("c".equalsIgnoreCase(str1)) {// 删除
                System.out.println("请输入您要删除的联系人的姓名是?");
                String name1 = sc.nextLine();
                System.out.println("您确定要删除的联系人的姓名是" + name1 + "确定为Y,不确定为N");
                String name2 = sc.nextLine();
                if ("y".equalsIgnoreCase(name2)) {
                    address.remove(name1);
                } else if ("n".equalsIgnoreCase(name2)) {
                    System.out.println("您以否定,我们不会删除");
                } else {
                    System.out.println("您输入的不是Y和N,退出删除功能");
                }

            } else if ("d".equalsIgnoreCase(str1)) {// 显示

                address.show();

            } else if ("e".equalsIgnoreCase(str1)) {// 查询
                System.out.println("请输入您要查询的名字");

                String name = sc.nextLine();
                AddressList add = address.select(name);

                if (add != null) {
                    System.out.println("查询有此人");
                    System.out.println(add);
                } else {
                    System.out.println("查询无此人");
                }

            } else if ("f".equalsIgnoreCase(str1)) {// 根据手机号查询
                System.out.println("请输入您要查询的手机号");

                String name = sc.nextLine();
                AddressList add = address.select(name);

                if (add != null) {
                    System.out.println("查询有此人");
                    System.out.println(add);
                } else {
                    System.out.println("查询无此人");
                }
            } else if ("g".equalsIgnoreCase(str1)) {// 退出
                System.out.println("退出成功");
                break;
            } else {// 删除
                System.out.println("您输入的选项有误,请重新输入");
            }
        }
        sc.close();
    }
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
3月前
|
JavaScript Java 大数据
基于JavaWeb的销售管理系统设计系统
本系统基于Java、MySQL、Spring Boot与Vue.js技术,构建高效、可扩展的销售管理平台,实现客户、订单、数据可视化等全流程自动化管理,提升企业运营效率与决策能力。
|
4月前
|
消息中间件 Java Kafka
Java 事件驱动架构设计实战与 Kafka 生态系统组件实操全流程指南
本指南详解Java事件驱动架构与Kafka生态实操,涵盖环境搭建、事件模型定义、生产者与消费者实现、事件测试及高级特性,助你快速构建高可扩展分布式系统。
250 7
|
2月前
|
移动开发 监控 小程序
java家政平台源码,家政上门清洁系统源码,数据多端互通,可直接搭建使用
一款基于Java+SpringBoot+Vue+UniApp开发的家政上门系统,支持小程序、APP、H5、公众号多端互通。涵盖用户端、技工端与管理后台,支持多城市、服务分类、在线预约、微信支付、抢单派单、技能认证、钱包提现等功能,源码开源,可直接部署使用。
196 24
|
5月前
|
存储 Java 数据库连接
java 初学者必看的系统知识结构图详解
本文详解Java知识结构图,涵盖Java语言基础、JVM原理、集合框架、并发编程、网络通信及主流框架(如Spring Boot、MyBatis),并结合学生信息管理系统实例,帮助初学者构建完整知识体系,提升实战开发能力。
173 0
|
2月前
|
设计模式 消息中间件 传感器
Java 设计模式之观察者模式:构建松耦合的事件响应系统
观察者模式是Java中常用的行为型设计模式,用于构建松耦合的事件响应系统。当一个对象状态改变时,所有依赖它的观察者将自动收到通知并更新。该模式通过抽象耦合实现发布-订阅机制,广泛应用于GUI事件处理、消息通知、数据监控等场景,具有良好的可扩展性和维护性。
252 8
|
6月前
|
数据采集 前端开发 JavaScript
产科专科电子病历系统基于Java开发,实现与HIS、LIS、PACS及区域妇幼信息平台的三级互联互通
产科专科电子病历系统基于Java开发,采用前后端分离架构(Vue+ElementUI前端,MySQL数据库),实现与HIS、LIS、PACS及区域妇幼信息平台的三级互联互通。系统涵盖患者全息视图、快速智能录入、检验检查模块、智能高危评估、异常值提醒及自我监测等功能,支持孕期时间轴和综合评估,自动归集数据并完成高危评分,助力产科数据标准化、结构化,以及临床保健工作的全程智能化管理。
175 1
|
2月前
|
安全 前端开发 Java
使用Java编写UDP协议的简易群聊系统
通过这个基础框架,你可以进一步增加更多的功能,例如用户认证、消息格式化、更复杂的客户端界面等,来丰富你的群聊系统。
169 11
|
2月前
|
机器学习/深度学习 人工智能 自然语言处理
Java与生成式AI:构建内容生成与创意辅助系统
生成式AI正在重塑内容创作、软件开发和创意设计的方式。本文深入探讨如何在Java生态中构建支持文本、图像、代码等多种生成任务的创意辅助系统。我们将完整展示集成大型生成模型(如GPT、Stable Diffusion)、处理生成任务队列、优化生成结果以及构建企业级生成式AI应用的全流程,为Java开发者提供构建下一代创意辅助系统的完整技术方案。
200 10
|
2月前
|
人工智能 监控 Java
Java与AI智能体:构建自主决策与工具调用的智能系统
随着AI智能体技术的快速发展,构建能够自主理解任务、制定计划并执行复杂操作的智能系统已成为新的技术前沿。本文深入探讨如何在Java生态中构建具备工具调用、记忆管理和自主决策能力的AI智能体系统。我们将完整展示从智能体架构设计、工具生态系统、记忆机制到多智能体协作的全流程,为Java开发者提供构建下一代自主智能系统的完整技术方案。
405 4
|
2月前
|
机器学习/深度学习 分布式计算 Java
Java与图神经网络:构建企业级知识图谱与智能推理系统
图神经网络(GNN)作为处理非欧几里得数据的前沿技术,正成为企业知识管理和智能推理的核心引擎。本文深入探讨如何在Java生态中构建基于GNN的知识图谱系统,涵盖从图数据建模、GNN模型集成、分布式图计算到实时推理的全流程。通过具体的代码实现和架构设计,展示如何将先进的图神经网络技术融入传统Java企业应用,为构建下一代智能决策系统提供完整解决方案。
328 0