JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。是Java访问数据库的标准规范,JDBC提供了一种基准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序。

原理:

  Java提供访问数据库规范称为JDBC,而生产厂商提供规范的实现类称为驱动。

  JDBC是接口,驱动是接口的实现类,没有驱动将无法完成数据库连接,从而不能操作数据库!每个数据库厂商都需要提供自己的驱动,用来连接自己公司的数据库,也就是说驱动一般都由数据库生成厂商提供。

我对JDBC的理解:JDBC就是用了让代码能更好的与数据库连接而由数据库厂商提供的接口,驱动是其实现类。使用JDBC需要几个步骤,同时对于增删改查也分为两种不同的操作,为了避免设置拼串时可能出现异常,使用preparedStatement进行预处理,为了减少代码量,可以将相同的代码封装到一个工具类内

MYSQL数据库:MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

简单记事本代码如下:

package note;

import java.awt.Color;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import javax.swing.JFileChooser;
import javax.swing.JFrame;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JTextArea; //让其继承窗口类
public class TextPad extends JFrame implements ActionListener {
private static final long serialVersionUID = 1L; //定义一个文本框
JTextArea jTextArea = null;//定义一个菜单栏
JMenuBar jMenuBar = null; //定义一个菜单
JMenu jMenu1 = null;
JMenuItem jMenuItem1 = null;
JMenuItem jMenuItem2 = null;
JMenuItem jMenuItem3 = null;
JMenuItem jMenuItem5 = null;
JFileChooser jFileChooser = null;
FileReader fileReader = null;
FileWriter fileWriter = null;
BufferedReader bufferedReader = null;
BufferedWriter bufferedWriter = null;
@SuppressWarnings("unused")
public static void main(String[] args) {
//实例化
TextPad notePal = new TextPad(); }
public TextPad() {
jTextArea = new JTextArea();//实例化jTextArea
jMenuBar = new JMenuBar();//实例化jMenuBar
jMenu1 = new JMenu("文件");
jMenuItem1 = new JMenuItem("新建");
jMenuItem1.addActionListener(this);
jMenuItem1.setActionCommand("新建");
jMenuItem2 = new JMenuItem("打开");
jMenuItem2.addActionListener(this);
jMenuItem2.setActionCommand("打开");
jMenuItem3 = new JMenuItem("保存");
jMenuItem3.addActionListener(this);
jMenuItem3.setActionCommand("保存");
jMenuItem5 = new JMenuItem("关闭");
jMenuItem5.addActionListener(this);
jMenuItem5.setActionCommand("关闭");
jTextArea.setBackground(Color.WHITE);//设置jTextArea的背景颜色为
this.setJMenuBar(jMenuBar);
jMenuBar.add(jMenu1);
jMenu1.add(jMenuItem1);
jMenu1.add(jMenuItem2);
jMenu1.add(jMenuItem3);
jMenu1.add(jMenuItem5);
this.add(jTextArea);
this.setTitle("记事本(简单版)");
this.setSize(800,600);
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
this.setVisible(true); } @Override public void actionPerformed(ActionEvent e)
{
if(e.getActionCommand().equals("打开")) {
jFileChooser = new JFileChooser();
jFileChooser.setDialogTitle("选择自己的文件... ...");
jFileChooser.showOpenDialog(null);
jFileChooser.setVisible(true);
String address = jFileChooser.getSelectedFile().getAbsolutePath();
try { fileReader = new FileReader(address);
bufferedReader = new BufferedReader(fileReader);
String str = "";
String strAll = "";
while((str = bufferedReader.readLine()) != null) { strAll += str + "\r\n";//将strAll中的全部信息显示到JTextArea上 }
jTextArea.setText(strAll); } catch (Exception e2)
{
e2.printStackTrace(); }
finally{ try { bufferedReader.close(); fileReader.close(); }
catch (Exception e3)
{
e3.printStackTrace(); }
} } if(e.getActionCommand().equals("保存")) {
JFileChooser jFileChooser1 = new JFileChooser();//创建一个保存窗口 jFileChooser1.setDialogTitle("另存为... ...");//设置窗口名字
jFileChooser1.showSaveDialog(null);//设置默认设置
jFileChooser1.setVisible(true);//显示窗口
try {
fileWriter = new FileWriter(jFileChooser1.getSelectedFile().getAbsolutePath());//为fileWrite分配空间
bufferedWriter = new BufferedWriter(fileWriter);//为bufferedWrite分配空间
bufferedWriter.write(this.jTextArea.getText());//保存进去
}
catch (Exception e2){
e2.printStackTrace(); }finally{
try { bufferedWriter.close(); fileWriter.close(); } catch (Exception e3) { e3.printStackTrace(); } } } } }

运行截图如下:





简单记事本的基本实现&十四周总结的更多相关文章

  1. C++走向远洋——60(十四周阅读程序、STL中的简单容器和迭代器)

    */ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...

  2. 201521123122 《java程序设计》第十四周学习总结

    ## 201521123122 <java程序设计>第十四周实验总结 ## 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多数据库相关内容. 2. 书面作业 1. M ...

  3. 第十四周实验报告:实验四 Android程序设计

    20162317袁逸灏 第十四周实验报告:实验四 Android程序设计 实验内容 Android Studio 实验要求 学会使用Android Studio 学习 活动 以及相关知识内容 学习 U ...

  4. 201671010140. 2016-2017-2 《Java程序设计》java学习第十四周

      java学习第十四周       本周,主要精力放在了第十二章swing用户界面组件知识的学习,swing是一个用于开发Java应用程序用户界面的开发工具包.它以抽象窗口工具包(AWT)为基础使跨 ...

  5. 第十四周(OOP版电子词典)

    /* *copyright(c) 2015,烟台大学计算机学院 *All rights reserved. *文件名:第十四周(OOP版电子词典) *作者:王忠 *完毕日期:2015.6.10 *版本 ...

  6. 201871010105-曹玉中《面向对象程序设计(java)》第十四周学习总结

    201871010105-曹玉中<面向对象程序设计(java)>第十四周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ ...

  7. 201871010106-丁宣元 《面向对象程序设计(java)》第十四周学习总结

    201871010106-丁宣元 <面向对象程序设计(java)>第十四周学习总结 正文开头: 项目 内容 这个作业属于哪个课程 https://home.cnblogs.com/u/nw ...

  8. 201871010107-公海瑜《面向对象程序设计(java)》第十四周学习总结

    201871010107-公海瑜<面向对象程序设计(java)>第十四周学习总结             项目                            内容   这个作业属于 ...

  9. 201871010135 张玉晶《面向对象程序设计(java)》第十四周学习总结

    项目 内容 这个作业属于哪个过程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/zyja/p/11963 ...

随机推荐

  1. 一个web应用的诞生(5)

    下面把角色分为两种,普通用户和管理员用户,至少对于普通用户来说,直接修改DB是不可取的,要有用户注册的功能,下面就开始进行用户注册的开发. 用户表 首先要想好用户注册的时候需要提供什么信息:用户名.密 ...

  2. webpack多页应用

    本文主要讲了webpack怎么搭建多页应用,熟悉下webpack的基本用法. 新建文件夹,目录结构如下: 然后 cd webpack-test npm init(根目录下创建了一个pakage.jso ...

  3. chrome 开发者工具 - local overrides

    使用chrome 作为本地网络服务 chrome 65+ 新功能, 使用我们自己的本地资源覆盖网页所使用的资源,可以使用本地css文件覆盖网页的css文件,修改样式. 类似的,使用DevTools的工 ...

  4. asp.net mvc + vue.js + axios.js

    1.新建一个 MVC 应用程序 2.右键解决方案 添加VUE 3.搜索vue 1.安装axios.js ,用于数据请求,get , post axios

  5. python-pillow图像处理

    安装 pip3 install pillow PIL中所涉及的基本概念有如下几个:通道(bands).模式(mode).尺寸(size).坐标系统(coordinate system).调色板(pal ...

  6. UIScrollView的简单使用

    UIScrollView *scrollView = [[UIScrollView alloc] initWithFrame:self.view.bounds]; //将scrollView添加到当前 ...

  7. mysql 8.0.16 单主 mgr搭建

    mysql 8.0.16 单主 mgr搭建 环境介绍: 192.168.142.142 db142192.168.142.143 db143192.168.142.145 db145 1.安装依赖包 ...

  8. PIXI兼容微信小游戏

    首先导入官方的weapp-adapter,然后导入pixi.min.js,微信小程序使用ES6的module引用模块,具体参见ES6的Module. import './libs/weapp-adap ...

  9. z-tree的使用

    1.参考资料 1)官网:http://www.treejs.cn/v3/api.php 2)z-tree码云:https://gitee.com/zTree/zTree_v3 2.下载解压 案例演示: ...

  10. MYSQL安装失败,一打开就出现MySQL-Workbench已停止工作

    1.由于系统重新安装,环境都是新的,出现MySQL-Workbench已停止工作 解决:下载  微软常用运行库合集  安装即可