此次开发工具为eclipse,才有的数据库驱动是mysql-connector-java-5.1.8-bin.jar

第一步,在eclipse的工程目录中引用mysql驱动

驱动下载地址:https://dev.mysql.com/downloads/connector/j/

选择build path 然后选择configure build path

再选择libraries,选择add external library,找到之前下的数据库驱动,确认,ok

然后下一段测试代码将数据库驱动起来

public class test {

    public static void main(String []args) {
try {
//mysql数据库设置驱动程序类型
Class.forName("com.mysql.jdbc.Driver");
System.out.println("mysql数据库驱动加载成功"); }
catch(ClassNotFoundException e) {
e.printStackTrace();
}
}
}

驱动代码运行一次就行了,之后就是操作数据库了

基本操作增改删查,原理都是一样的

先创建一个Connection对象

Connection connection = null;
String user="root";//用户名
String password="19980713";//密码
String url = "jdbc:mysql://localhost:3306/task?user="+user+"&password="+password+"&useUnicode=true&characterEncoding=utf-8";//获得连接的语句
try{
connection = (Connection)DriverManager.getConnection(url);
}catch(SQLException e){
e.printStackTrace();
}

获得连接之后就是对connection进行操作了

查询记录

String sql = "select id,name,job,department,state,authority from worker;";
try { PreparedStatement ps = (PreparedStatement) connection.prepareStatement(sql);//预编译过程
ResultSet rs = ps.executeQuery();//查询一般用executeQuery,返回的是查询的结果集
//下面是对结果集进行操作
while(rs.next()) {
count++;
Vector v = new Vector();
v.add((rs.getString(1)));
v.add((rs.getString(2)));
v.add((rs.getString(3)));
v.add((rs.getString(4)));
v.add((rs.getString(5)));
v.add((rs.getString(6)));
worker.add(v);
}
}catch(SQLException e1) {
e1.printStackTrace();
}

插入记录

String sql = "insert into worker(name) "
+"value("+ ""\"小明"\"" + ")";
PreparedStatement ps = (PreparedStatement) connection.prepareStatement(sql);
try {
PreparedStatement ps = (PreparedStatement) connection.prepareStatement(sql);
if(ps.executeUpdate()==1){//返回一个int值表示返回的条数
int n = JOptionPane.showConfirmDialog(null, "添加成功,是否继续添加?", "系统提示",JOptionPane.YES_NO_OPTION);
if(n == 0){
//清空面板
name.setText("");
sex.setText("");
authority.setText("");
birthday.setText("");
department.setText("");
job.setText("");
email.setText("");
state.setText("");
remark.setText("");
specialty.setText("");
address.setText("");
tel.setText("");
edu_level.setText("");
}else{
dispose();
JoinNewMember frame = new JoinNewMember();
}
}
} catch (SQLException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}

 其余操作就不贴代码了,以此类推就是的,我先准备一下六级去了,要不待会再来更新

2018/06/16/18:39更新 考完六级回来了 段落匹配放最后面的  没做完 亏了  十二月份再来哈哈哈哈

补上:

上面之所以不贴代码是因为套路都一样

先实例化一个Connection对象,然后调用prepareStatement()将SQL语句带入其中进行预编译

然后根据情况调用execute executeUpdate 或者executeQuery

下面来了解一下这三个函数execute() executeQuery() executeUpdate()的区别和适用情况

executeQuery()顾名思义----执行查询

返回的是一个结果集,我们对结果集进行处理得到我们想要的数据.

结果集的组成是行列的,行是指例句,列指属性,rs.next()可以看做一个迭代过程

executeUpdate顾名思义---执行更新

对应的一般就是用于执行 INSERT、UPDATE 或 DELETE或者一些定义数据库的语句,例如CREATE TABLE等,返回值是执行操作收到影响的行数

关于execute,我刚开始以为挺简单的,后来才发现我低估了他的用途,我等菜鸟不敢随意总结,我在别的地方看到一个挺好的详解:

方法execute

												

java操作数据库的基本方法的更多相关文章

  1. java操作数据库:增删改查

    不多bb了直接上. 工具:myeclipse 2016,mysql 5.7 目的:java操作数据库增删改查商品信息 test数据库的goods表 gid主键,自增 1.实体类Goods:封装数据库数 ...

  2. JDBC数据源(DataSource)数据源技术是Java操作数据库的一个很关键技术,流行的持久化框架都离不开数据源的应用。

    JDBC数据源(DataSource)的简单实现   数据源技术是Java操作数据库的一个很关键技术,流行的持久化框架都离不开数据源的应用. 2.数据源提供了一种简单获取数据库连接的方式,并能在内部通 ...

  3. Java操作数据库——手动实现数据库连接池

    Java操作数据库——手动实现数据库连接池 摘要:本文主要学习了如何手动实现一个数据库连接池,以及在这基础上的一些改进. 部分内容来自以下博客: https://blog.csdn.net/soonf ...

  4. Java操作数据库——使用JDBC连接数据库

    Java操作数据库——使用JDBC连接数据库 摘要:本文主要学习了如何使用JDBC连接数据库. 背景 数据持久化 数据持久化就是把数据保存到可掉电式存储设备中以供之后使用.大多数情况下,特别是企业级应 ...

  5. JDBC 数据库连接 Java操作数据库 jdbc快速入门

    JDBC基本概念 Java DataBase Connectivity 数据库连接 java操作数据库 本质上(sun公司的程序员)定义的一套操作关系型数据库的规则 既接口  更新内容之前 代码 pa ...

  6. Java操作数据库——使用连接池连接数据库

    Java操作数据库——使用连接池连接数据库 摘要:本文主要学习了如何使用JDBC连接池连接数据库. 传统方式和连接池方式 传统方式的步骤 使用传统方式在Java中使用JDBC连接数据库,完成一次数据库 ...

  7. Java操作数据库——在JDBC里使用事务

    Java操作数据库——在JDBC里使用事务 摘要:本文主要学习了如何在JDBC里使用事务. 使用Connection的事务控制方法 当JDBC程序向数据库获得一个Connection对象时,默认情况下 ...

  8. JDBC 4.0 开始Java操作数据库不用再使用 Class.forName加载驱动类了

    JDBC 4.0 开始Java操作数据库不用再使用 Class.forName加载驱动类了 代码示例 转自 https://docs.oracle.com/javase/tutorial/jdbc/o ...

  9. java操作数据库:分页查询

    直接上.... 还是用之前的goods表,增加了一些数据 1.实体类Goods // 封装数据 public class Goods { private int gid; private String ...

随机推荐

  1. Devops 到底是什么?(转)

    出处:https://www.cnblogs.com/servicehot/p/6510199.html 过去一年以来,一批来自欧美的.不墨守陈规的系统管理员和开发人员一直在谈论一个新概念:DevOp ...

  2. 用 ASP.NET MVC 实现基于 XMLHttpRequest long polling(长轮询) 的 Comet(转)

    轮询:客户端定时向服务器发送Ajax请求,服务器接到请求后马上返回响应信息并关闭连接. 优点:后端程序编写比较容易. 缺点:请求中有大半是无用,浪费带宽和服务器资源. 实例:适于小型应用. 长轮询:客 ...

  3. [转载]使用PHP_CodeSniffer规范php代码

    为什么使用PHP_CodeSniffer 一个开发团队统一的编码风格,有助于他人对代码的理解和维护,对于大项目来说尤其重要. PHP_CodeSniffer是PEAR中的一个用PHP5写的用来检查嗅探 ...

  4. mysql学习之路_连接查询

    回顾 列属性:主键,自增长,唯一键. 关系:一对一,一对多,多对多 三层范式: 1NF:字段设计必须符合原子性 2NF:不存在部分依赖(没有复合主键) 3NF:不存在传递依赖(实体单独成表) 逆规范化 ...

  5. oracle死锁解决方法

    select SESS.sid, SESS.SERIAL#, LO.ORACLE_USERNAME, LO.OS_USER_NAME,      AO.OBJECT_NAME, LO.LOCKED_M ...

  6. load data妙用

    load变量和用户变量的巧妙结合,实现灵活导入字段列(NO.1) LOAD DATA INFILE 'file.csv' INTO TABLE dados_meteo (@var1, @var2) S ...

  7. OpenCV人脸特效制作

    https://blog.csdn.net/zxc024000/article/details/50456917 https://blog.csdn.net/huanghuangjin/article ...

  8. Alpha阶段敏捷冲刺(八)

    1.站立式会议 提供当天站立式会议照片一张 2.每个人的工作 (有work item 的ID),并将其记录在码云项目管理中: 昨天已完成的工作. 祁泽文:写了关于统计的按钮的代码. 徐璐琳:完善了&q ...

  9. POJ2139--Six Degrees of Cowvin Bacon(最简单Floyd)

    The cows have been making movies lately, so they are ready to play a variant of the famous game &quo ...

  10. noip第17课作业

    1.  召见骑士 [问题描述] 某王国有5位骑士,每位骑士都有自己的编号,且这个王国的编号都为奇数,分别为1,3,5,7,9,在国王召见他们之前他们都必须经过只能从一边进出的长廊,长廊的宽度只能坐一个 ...