59.【初识JFrame和数据库——聊天系统】(四)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 59.【初识JFrame和数据库——聊天系统】

14.微信项目(聊天与登入功能)

<聊天界面>

import javax.swing.*;
import java.awt.*;
public class panel extends JFrame{
    public panel(){
        this.setSize(400,400);  //长宽
        this.setLocationRelativeTo(null);   //居中
        //设置按钮框
        JButton Send=new JButton("发送");
        JComboBox List=new JComboBox();    //当设置多选框的时候,多选框自己带一个组件
        List.addItem("张三");
        List.addItem("李四");
        List.addItem("王二");
        //设置文本文框
        JTextField Front=new JTextField();
        JTextArea Gitee=new JTextArea();
        //设置滑轮操作
        JScrollPane Roll=new JScrollPane(Gitee);   //添加滑轮的时候,要注意我们添加到哪里,就把添加的对象放进去
        //进行多选框和发送合体
        JPanel jp1=new JPanel();
        jp1.setLayout(new GridLayout(1,2));
        jp1.add(List);
        jp1.add(Send);
        //进行上框和多选框的合体
        JPanel jp2=new JPanel();
        jp2.setLayout(new GridLayout(2,1));
        jp2.add(Front);
        jp2.add(jp1);
        //进行上下框进行合体
        JPanel jp3=new JPanel();
        jp3.setLayout(new GridLayout(1,1));
        jp3.add(jp2);
        //开始合并
        this.setLayout(new BorderLayout());
        this.add(jp3,BorderLayout.NORTH);
        this.add(Roll,BorderLayout.CENTER);     //只需要写一个滑轮的即可
    }
}

<主界面>

import javax.swing.*;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.sql.*;
public class Student extends JFrame implements ActionListener {
    //按钮
    JButton jb1 = new JButton("查询");
    JButton jb2 = new JButton("删除");
    JButton jb3 = new JButton("增加");
    JButton jb4 = new JButton("更改");
    JButton jb5 = new JButton("登入");
    JButton jb6 = new JButton("退出");
    //输入框
    JTextField Tid = new JTextField();
    JTextField Tna = new JTextField();
    JTextField Tse = new JTextField();
    JTextField Tbi = new JTextField();
    JTextField Tph = new JTextField();
    public JButton getJb1() {
        return jb1;
    }
    public JButton getJb2() {
        return jb2;
    }
    public JButton getJb3() {
        return jb3;
    }
    public JButton getJb4() {
        return jb4;
    }
    public JButton getJb5() {
        return jb5;
    }
    public JButton getJb6() {
        return jb6;
    }
    public JTextField getTid() {
        return Tid;
    }
    public JTextField getTna() {
        return Tna;
    }
    public JTextField getTse() {
        return Tse;
    }
    public JTextField getTbi() {
        return Tbi;
    }
    public JTextField getTph() {
        return Tph;
    }
    //设置框架
    public Student() {
        this.setSize(450, 400);
        this.setLocationRelativeTo(null);
        //设置按钮布局
        JPanel Button = new JPanel();
        Button.setLayout(new FlowLayout());
        Button.add(jb5);
        Button.add(jb1);
        Button.add(jb2);
        Button.add(jb3);
        Button.add(jb4);
        Button.add(jb6);
        //设置标签
        JLabel id = new JLabel("学号");
        JLabel name = new JLabel("姓名");
        JLabel sex = new JLabel("性别");
        JLabel birthday = new JLabel("生日");
        JLabel phone = new JLabel("电话");
        //设置输入框
        //进行文本框整合
        JPanel Information = new JPanel();
        Information.setLayout(new GridLayout(5, 2));
        Information.add(id);
        Information.add(Tid);
        Information.add(name);
        Information.add(Tna);
        Information.add(sex);
        Information.add(Tse);
        Information.add(birthday);
        Information.add(Tbi);
        Information.add(phone);
        Information.add(Tph);
        //进行整体汇总
        this.setLayout(new BorderLayout());
        this.add(Button, BorderLayout.SOUTH);
        this.add(Information, BorderLayout.CENTER);
    }
    @Override
    public void actionPerformed(ActionEvent e) {
        String id=this.getTid().getText();
        String name=this.getTna().getText();
        String sex=this.getTse().getText();
        String birthday=this.getTbi().getText();
        String phone=this.getTph().getText();
    if(e.getActionCommand().equals(this.getJb1().getText()))   //查询
    {
        try {
            Class.forName("org.gjt.mm.mysql.Driver");
            try {
                Connection cn= DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/qq2","root","121788");
                String sql="select *from student where id=?";
                PreparedStatement ps=cn.prepareStatement(sql);
                ps.setString(1,id);
                ResultSet rs= ps.executeQuery();
                if(rs.next()){
                    System.out.println(rs.getString(1)+" "+rs.getString(2)+" "+rs.getString(3)+" "+rs.getString(4)+" "+rs.getString(5));
                }else{
                    JOptionPane.showMessageDialog(null,"未查询到相关信息");  //框体的形式输出
                }
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        } catch (ClassNotFoundException classNotFoundException) {
            classNotFoundException.printStackTrace();
        }
        System.out.println("点击了查询");
    }if(e.getActionCommand().equals(this.getJb2().getText()))   //删除
        {
            try {
                Class.forName("org.gjt.mm.mysql.Driver");
                try {
                    Connection cn=DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/qq2","root","121788");
                    String sql="delete from student where id=? and name=?";
                    PreparedStatement ps=cn.prepareStatement(sql);
                    ps.setString(1,id);
                    ps.setString(2,name);
                    ps.executeUpdate();
                    ps=cn.prepareStatement("select *from student");
                    ResultSet rs=ps.executeQuery();
                    if(rs.next()){
                        System.out.println("删除的数据是:"+" "+rs.getString(1)+" "+rs.getString(2)+" "+rs.getString(3)+" "+rs.getString(4)+" "+rs.getString(5));
                    }else{
                        JOptionPane.showMessageDialog(null,"删除失败");  //框体的形式输出
                    }
                } catch (SQLException throwables) {
                    throwables.printStackTrace();
                }
            } catch (ClassNotFoundException classNotFoundException) {
                classNotFoundException.printStackTrace();
            }
            System.out.println("点击了删除");
        }if(e.getActionCommand().equals(this.getJb3().getText()))//增加
        {
            try {
                Class.forName("org.gjt.mm.mysql.Driver");
                try {
                    Connection cn=DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/qq2","root","121788");
                    String sql="insert into student(id,name,sex,brithday,phone) values (?,?,?,?,?)";
                    PreparedStatement ps=cn.prepareStatement(sql);
                    ps.setString(1,id);
                    ps.setString(2,name);
                    ps.setString(3,sex);
                    ps.setString(4,birthday);
                    ps.setString(5,phone);
                    ps.executeUpdate();
                   ps=cn.prepareStatement("select *from student");
                   ResultSet rs=ps.executeQuery();
                    if(rs.next()){
                        System.out.println("创建了:"+" "+rs.getString(1)+" "+rs.getString(2)+" "+rs.getString(3)+" "+rs.getString(4)+" "+rs.getString(5));
                    }else{
                        JOptionPane.showMessageDialog(null,"未查询到相关信息");  //框体的形式输出
                    }
                } catch (SQLException throwables) {
                    throwables.printStackTrace();
                }
            } catch (ClassNotFoundException classNotFoundException) {
                classNotFoundException.printStackTrace();
            }
            System.out.println("点击了增加");
        }if(e.getActionCommand().equals(this.getJb4().getText()))//更改
        {
            try {
                Class.forName("org.gjt.mm.mysql.Driver");
                try {
                    Connection cn=DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/qq2","root","121788");
                    String sql="update student set phone=? where id=?";
                    PreparedStatement ps=cn.prepareStatement(sql);
                    ps.setString(1,phone);
                    ps.setString(2,id);
                    ps.executeUpdate();
                    ps=cn.prepareStatement("select *from student");
                    ResultSet rs=ps.executeQuery();
                    if(rs.next()){
                        System.out.println("更改了信息"+rs.getString(1));
                    }else{
                        JOptionPane.showMessageDialog(null,"更改失败!");  //框体的形式输出
                    }
                } catch (SQLException throwables) {
                    throwables.printStackTrace();
                }
            } catch (ClassNotFoundException classNotFoundException) {
                classNotFoundException.printStackTrace();
            }
            System.out.println("点击了更改");
        }if(e.getActionCommand().equals(this.getJb5().getText()))
        {
            try {
            Class.forName("org.gjt.mm.mysql.Driver");
            try {
                Connection cn=DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/qq2","root","121788");
                String sql="select *from student where id = ? and name = ? and sex = ? and brithday  =? and phone = ?";
                PreparedStatement ps=cn.prepareStatement(sql);
                ps.setString(1,id);
                ps.setString(2,name);
                ps.setString(3,sex);
                ps.setString(4,birthday);
                ps.setString(5,phone);
                ResultSet rs=ps.executeQuery();
                if(rs.next()){
                    panel p=new panel();
                    p.setVisible(true);
                    this.setVisible(false);
                }else{
                    JOptionPane.showMessageDialog(null,"信息错误");  //框体的形式输出
                }
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        } catch (ClassNotFoundException classNotFoundException) {
            classNotFoundException.printStackTrace();
        }
            System.out.println("点击了登入");
        }if(e.getActionCommand().equals(this.getJb6().getText()))
        {
            System.out.println("点击了退出");
            System.exit(0);
        }
    }
}

<主函数>

import javax.swing.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.sql.*;
public class hello {
    public static void main(String[] args) {
    //设置监听
        hello h=new hello();
        Student s=new Student();
       s.getJb1().addActionListener(s);
       s.getJb2().addActionListener(s);
       s.getJb3().addActionListener(s);
       s.getJb4().addActionListener(s);
       s.getJb5().addActionListener(s);
       s.getJb6().addActionListener(s);
        s.setVisible(true);
    }
}
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
SQL 数据库
59.【初识JFrame和数据库——聊天系统】(三)
59.【初识JFrame和数据库——聊天系统】
47 0
|
SQL Java 关系型数据库
59.【初识JFrame和数据库——聊天系统】(二)
59.【初识JFrame和数据库——聊天系统】
38 0
|
Java 数据库 数据安全/隐私保护
59.【初识JFrame和数据库——聊天系统】(一)
59.【初识JFrame和数据库——聊天系统】
53 0
|
23天前
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
|
25天前
|
存储 SQL 关系型数据库
使用MySQL Workbench进行数据库备份
【9月更文挑战第13天】以下是使用MySQL Workbench进行数据库备份的步骤:启动软件后,通过“Database”菜单中的“管理连接”选项配置并选择要备份的数据库。随后,选择“数据导出”,确认导出的数据库及格式(推荐SQL格式),设置存储路径,点击“开始导出”。完成后,可在指定路径找到备份文件,建议定期备份并存储于安全位置。
190 11
|
21天前
|
存储 SQL 关系型数据库
MySQL的安装&数据库的简单操作
本文介绍了数据库的基本概念及MySQL的安装配置。首先解释了数据库、数据库管理系统和SQL的概念,接着详细描述了MySQL的安装步骤及其全局配置文件my.ini的调整方法。文章还介绍了如何启动MySQL服务,包括配置环境变量和使用命令行的方法。最后,详细说明了数据库的各种操作,如创建、选择和删除数据库的SQL语句,并提供了实际操作示例。
59 13
MySQL的安装&数据库的简单操作
|
26天前
|
存储 SQL 关系型数据库
一篇文章搞懂MySQL的分库分表,从拆分场景、目标评估、拆分方案、不停机迁移、一致性补偿等方面详细阐述MySQL数据库的分库分表方案
MySQL如何进行分库分表、数据迁移?从相关概念、使用场景、拆分方式、分表字段选择、数据一致性校验等角度阐述MySQL数据库的分库分表方案。
121 14
一篇文章搞懂MySQL的分库分表,从拆分场景、目标评估、拆分方案、不停机迁移、一致性补偿等方面详细阐述MySQL数据库的分库分表方案
|
1天前
|
SQL 关系型数据库 MySQL
数据库:MYSQL参数max_allowed_packet 介绍
数据库:MYSQL参数max_allowed_packet 介绍
10 2
|
8天前
|
关系型数据库 Unix MySQL
MySQL是一种关系型数据库管理系统
MySQL是一种关系型数据库管理系统
22 2
|
11天前
|
Oracle NoSQL 关系型数据库
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
38 2