一、关键四元素

   ①    com.mysql.jdbc.Driver      mysql数据库连接jar包。   获取途径: 链接:https://pan.baidu.com/s/1SFcjuut5BsO-4x3U-SdG6Q        提取码:aafz   

  ②    private static final String URL = "jdbc:mysql://localhost:3306/zhaowejie?" + "useUnicode=true&characterEncoding=UTF8";   这是数据库的连接路径。

“jdbc”是协议开头。

“mysql”是子协议数据库名称,代表数据库是mysql。

//localhost:3306”是服务器的IP地址和端口,“zhaowejie?”代表你要连接得数据库的名字。

               "useUnicode=true&characterEncoding=UTF8" 指定操作数据库使用utf-8字符编码进行操作。

  ③   private static final String USER = "root";    数据库连接名。

  ④   private static final String USER = "root";    数据库连接密码。

二、代码实现

  

package machine;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class JDBCTest {

// 数据库连接ip,user,password需要修改
// private static final String
       private static final String URL = "jdbc:mysql://localhost:3306/zhaowejie?"+ "useUnicode=true&characterEncoding=UTF8";
       private static final String USER = "root";
  private static final String PASSWORD = "123456";

public static void main(String[] args) {

  Connection conn = null;
     Integer id = 0;
  String userName = null;
  String userPassWord = null;
try {
  // 1.加载驱动程序
  Class.forName("com.mysql.jdbc.Driver");
  // 2.获得数据库的连接
  conn = DriverManager.getConnection(URL, USER, PASSWORD);
  // 3.通过数据库的连接操作数据库,实现增删改查(使用Statement类)
  query(conn, 1);
  insert(conn, 3, "zhaoweijie", "123445");
  update(conn, "ws", "23456", 1);
} catch (ClassNotFoundException e) {
  e.printStackTrace();
} catch (SQLException e) {
  e.printStackTrace();
}
}

// 查询
private static void query(Connection conn, Integer id) throws SQLException {
  String sql = "SELECT id, userName , userPassWord FROM USERS WHERE id = ?";
  PreparedStatement ps = null;
  ResultSet rs = null;
try {
  ps = conn.prepareStatement(sql);
  ps.setInt(1, id);
  rs = ps.executeQuery();
  while (rs.next()) {
  id = rs.getInt(1);
  String userName = rs.getString(2);
  String userPassWord = rs.getString(3);
  System.out.println("id=" + id + "userName=" + userName + "userPassWord=" + userPassWord);
}
} catch (SQLException e) {
  e.printStackTrace();
} finally {
  rs.close();
conn.close();
  ps.close();
}
}

  // insert
  private static void insert(Connection conn, Integer id, String userName, String userPassWord) throws SQLException {

  int i = 0;
  // sql 插入的语句
  String s = "" + "insert into users(id,userName,userPassWord) values(?,?,?)";
  PreparedStatement ps = null;

  // ResultSet rs=null;
try {
  ps = conn.prepareStatement(s);
  ps.setInt(1, id);
  ps.setString(2, userName);
  ps.setString(3, userPassWord);
  i = ps.executeUpdate();
} catch (SQLException e) {
  e.printStackTrace();
} finally {
  // rs.close();
  conn.close();
  ps.close();
}
}

  // update
  private static void update(Connection conn, String userName, String userPassword, Integer id) throws SQLException {
  int i = 0;
  String sql = "update users set userName = " + "'" + userName + "'" + "," + "userPassword = " + "'"+ userPassword + "'" + " " + "where id = " + id;
  Statement ps = null;

  // ResultSet rs=null;
try {
  // ps = conn.prepareStatement(sql);
  ps = conn.createStatement();
  i = ps.executeUpdate(sql);
} catch (SQLException e) {
  e.printStackTrace();
} finally {
  // rs.close();
  conn.close();
  ps.close();
}
}
}

   

jdbc-手写Java方法连接数据库的更多相关文章

  1. 手写JAVA虚拟机(二)——实现java命令行

    查看手写JAVA虚拟机系列可以进我的博客园主页查看. 我们知道,我们编译.java并运行.class文件时,需要一些java命令,如最简单的helloworld程序. 这里的程序最好不要加包名,因为加 ...

  2. 手写JAVA虚拟机(三)——搜索class文件并读出内容

    查看手写JAVA虚拟机系列可以进我的博客园主页查看. 前面我们介绍了准备工作以及命令行的编写.既然我们的任务实现命令行中的java命令,同时我们知道java命令是将class文件(字节码)转换成机器码 ...

  3. 6 手写Java LinkedHashMap 核心源码

    概述 LinkedHashMap是Java中常用的数据结构之一,安卓中的LruCache缓存,底层使用的就是LinkedHashMap,LRU(Least Recently Used)算法,即最近最少 ...

  4. 3 手写Java HashMap核心源码

    手写Java HashMap核心源码 上一章手写LinkedList核心源码,本章我们来手写Java HashMap的核心源码. 我们来先了解一下HashMap的原理.HashMap 字面意思 has ...

  5. 手写redux方法以及数组reduce方法

    reduce能做什么? 1)求和 2)计算价格 3)合并数据 4)redux的compose方法 这篇文章主要内容是什么? 1)介绍reduce的主要作用 2)手写实现reduce方法 0)了解red ...

  6. 2 手写Java LinkedList核心源码

    上一章我们手写了ArrayList的核心源码,ArrayList底层是用了一个数组来保存数据,数组保存数据的优点就是查找效率高,但是删除效率特别低,最坏的情况下需要移动所有的元素.在查找需求比较重要的 ...

  7. 1 手写Java ArrayList核心源码

    手写ArrayList核心源码 ArrayList是Java中常用的数据结构,不光有ArrayList,还有LinkedList,HashMap,LinkedHashMap,HashSet,Queue ...

  8. 阿里第二轮面试:手写Java二叉树

    阿里面试 现在很多公司在招聘开发岗位的时候,都会事先在招聘信息中注明面试者应当具备的知识技能,而且在面试的过程中,有部分对于技能掌握程度有严格要求的公司还会要求面试者手写代码,这个环节很考验面试者的基 ...

  9. JavaScript手写new方法

    1.看一下正常使用的new方法 function father(name){ this.name=name; this.sayname=function(){ console.log(this.nam ...

随机推荐

  1. Fedora20在神州战神K650D1安装过程,使用netinstall和Dvd.iso镜像安装。

    最近新买一笔记本,神州战神K650D-i5 D1.仍旧安装双系统,WIndows7+Fedora20.磁盘分区是这样的: 第一主分区 /boot ext4 20G 第二主分区 / ext4 70G 第 ...

  2. 基于vue-cli-和element-ui的开发admin(1)

    //首先以下仅是记录个人本次vue后台管理系统的登录界面部分操作的流程以及踩坑的注意点 一.首先是搭建vue-cli工作环境 这里有两种方式:1.用npm:(在安装了vue,vue-cli以及webp ...

  3. sql select sql查询

    select 一.课上练习代码 1 查询所有学生信息 select * from tb_student; select * from tb_teacher; 2 查询所有课程名称及学分(投影和别名) ...

  4. Java项目集成Redis

    1.项目pom.xml中添加Jedis依赖 <dependency> <groupId>redis.clients</groupId> <artifactId ...

  5. 从春节送祝福谈谈 IO 模型(二)

    上期结合程序员小猿用温奶器给孩子热奶的故事,把面试中常聊的“同步.异步与阻塞.非阻塞有啥区别”简单进行普及. 不过,恰逢春节即将到来,应个景,不妨就通过实现新春送祝福的需求,深入了解一下 Java I ...

  6. Java技巧之——判断相等

    变量值的判断是java中重要的一部分 通常我们判断两个值是否相等,使用的是两个等号 == 为了防止少写一个等号,造成无法挽回的失误,判断写为下面的格式 int a; 12==a; 原理是不能将任何东西 ...

  7. LeetCode#141-Linked List Cycle-环形链表

    一.题目 给定一个链表,判断链表中是否有环. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始). 如果 pos 是 -1,则在该链表中没有环. 示例 1 ...

  8. golang--安装golang并安装grpc-grpcgateway环境

    安装goland环境 下载golang安装包,国内环境打开https://studygolang.com/dl,国外环境打开https://golang.google.cn/dl/下载对应系统的安装包 ...

  9. 世界疫情app柱形图显示

    访问云服务器的mysql实现数据的获取.最后通过柱形图的形式将数据显示在页面上: 遇到的主要困难时对于云服务器的mysql连接本地的navicat之间事情,最后通过网上的各种解决办法完成了相关的内容. ...

  10. MTK Android 计算器Calculator输入暗码!77!+,启动工厂测试apk

    Android8.0 计算器Calculator输入暗码!77!+,启动工厂测试apk 路径: packages/apps/ExactCalculator/src/com/android/calcul ...