jdbc连接mysql并执行简单的CRUD的步骤:

1.注册驱动(需要抛出/捕获异常)

Class.forName("com.mysql.jdbc.Driver");

2.建立连接需要抛出/捕获异常)

connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/testdb", "root", "Danny2036");

3.创建statement

statement = connection.createStatement();

4.创建sql语句

String sql = "insert into user values(10, \"noname\", 31)";

5.执行sql语句,如果是查询需要用ResultSet接收结果集

int affectrows = statement.executeUpdate(sql);
System.out.println(affectrows);

6.关闭资源

if (statement != null) {
statement.close();
}
if (connection != null) {
connection.close();
}

————————————————————————分割线——————————————————————————————————

最后贴出全部代码(包括insert,selectOne和selectAll)

package com.colin.dao;

import java.sql.*;

public class JdbcTest {

    /**
* 插入语句
* @param id 主键id int
* @param name 姓名 String
* @param age 年龄 int
*/
public static void update(int id, String name, int age) throws SQLException {
long starttime = System.currentTimeMillis(); Connection connection = null;
Statement statement = null;
try {
Class.forName("com.mysql.jdbc.Driver");
connection = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/testdb",
"root", "Danny2036");
statement = connection.createStatement();
String sql = "update user set name = \'" + name + "\', age = "+ age +" where id = " + id;
System.out.println(sql);
int affectrows = statement.executeUpdate(sql);
System.out.println(affectrows); } catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} finally {
if (connection != null) {
connection.close();
}
if (statement != null) {
statement.close();
}
} System.out.println(System.currentTimeMillis() - starttime); } public static void selectOne(int id) throws ClassNotFoundException, SQLException { Statement statement = null;
Connection connection = null; try {
// 注册驱动
Class.forName("com.mysql.jdbc.Driver");
// 建立连接
connection = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/testdb",
"root", "Danny2036"
);
// 创建statement
statement = connection.createStatement();
// 定义sql语句
String sql = "SELECT id, name, age FROM user where id = " + id;
// 执行sql语句并获得结果
ResultSet resultSet = statement.executeQuery(sql);
// 遍历结果集
while (resultSet.next()) {
int idResult = (int) resultSet.getInt("id");
String nameResult = (String) resultSet.getString("name");
int ageResult = (int) resultSet.getInt("age"); System.out.println(idResult + "\t" + nameResult + "\t" + ageResult);
}
} finally {
if (statement != null) {
statement.close();
}
if (connection != null) {
connection.close();
}
} } public static void selectAll() throws ClassNotFoundException, SQLException { Statement statement = null;
Connection connection = null; try {
// 注册驱动
Class.forName("com.mysql.jdbc.Driver");
// 建立连接
connection = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/testdb",
"root", "Danny2036"
);
// 创建statement
statement = connection.createStatement();
// 定义sql语句
String sql = "SELECT id, name, age FROM user";
// 执行sql语句并获得结果
ResultSet resultSet = statement.executeQuery(sql);
// 遍历结果集
while (resultSet.next()) {
int idResult = (int) resultSet.getInt("id");
String nameResult = (String) resultSet.getString("name");
int ageResult = (int) resultSet.getInt("age"); System.out.println(idResult + "\t" + nameResult + "\t" + ageResult);
}
} finally {
if (statement != null) {
statement.close();
}
if (connection != null) {
connection.close();
}
} } public static void main(String[] args) throws SQLException, ClassNotFoundException {
selectAll();
} /* // 向上抛异常的方式
public static void main(String[] args)
throws ClassNotFoundException, SQLException { long starttime = System.currentTimeMillis(); Connection connection = null;
Statement statement = null; try {
//注册驱动
Class.forName("com.mysql.jdbc.Driver");
//建立连接
connection = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/testdb",
"root", "Danny2036");
//创建statement
statement = connection.createStatement();
//定义sql
String sql = "insert into user values(10, \"noname\", 31)";
//执行sql,如果是查询需返回结果集
int affectrows = statement.executeUpdate(sql);
System.out.println(affectrows); } finally { //关闭资源
if (statement != null) {
statement.close();
}
if (connection != null) {
connection.close();
} } System.out.println("总执行时间: " + (System.currentTimeMillis() - starttime)); }
*/ /* // 捕获异常的方式
public static void main(String[] args) throws SQLException { long starttime = System.currentTimeMillis(); Statement statement = null;
Connection connection = null;
try {
// 注册驱动
Class.forName("com.mysql.jdbc.Driver");
// 建立连接
connection = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/testdb?useSSL=true",
"root", "Danny2036");
// 创建statement
statement = connection.createStatement();
// 定义sql
String sql = "insert into user values(9, \"ahaha\", 22)";
// 执行sql,如果是查询,遍历结果集
int affectrows = statement.executeUpdate(sql);
System.out.println(affectrows); } catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} finally { // 关闭资源
if (statement != null) {
statement.close();
}
if (connection != null) {
connection.close();
} } System.out.println("总用时 : " + (System.currentTimeMillis() - starttime)); }
*/ }

——————————————————**********最后附上bean代码***********————————————————————

package com.colin.bean;

public class User {

    private int id;
private String name;
private int age; public User(int id, String name, int age) {
this.id = id;
this.name = name;
this.age = age;
} public User(String name, int age) {
this.name = name;
this.age = age;
} public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} @Override
public String toString() {
return "User{" +
"id=" + id +
", name='" + name + '\'' +
", age=" + age +
'}';
}
}

jdbc笔记(一) 使用Statement对单表的CRUD操作的更多相关文章

  1. jdbc笔记(二) 使用PreparedStatement对单表的CRUD操作

    首先声明,本文只给出代码,并不是做教程用,如有不便之处,还请各位见谅. PreparedStatement相较于Statement,概括来说,共有三个优势: 1. 代码的可读性和易维护性:Prepar ...

  2. 【Java EE 学习 44】【Hibernate学习第一天】【Hibernate对单表的CRUD操作】

    一.Hibernate简介 1.hibernate是对jdbc的二次开发 2.jdbc没有缓存机制,但是hibernate有. 3.hibernate的有点和缺点 (1)优点:有缓存,而且是二级缓存: ...

  3. 6.单表的CRUD操作

    1.插入后用新id初始化被插入对象 <insert id="insertStudentCatchId"> insert into student (age,name,s ...

  4. SQLServer学习笔记<>.基础知识,一些基本命令,单表查询(null top用法,with ties附加属性,over开窗函数),排名函数

    Sqlserver基础知识 (1)创建数据库 创建数据库有两种方式,手动创建和编写sql脚本创建,在这里我采用脚本的方式创建一个名称为TSQLFundamentals2008的数据库.脚本如下:   ...

  5. Django学习笔记(10)——Book单表的增删改查页面

    一,项目题目:Book单表的增删改查页面 该项目主要练习使用Django开发一个Book单表的增删改查页面,通过这个项目巩固自己这段时间学习Django知识. 二,项目需求: 开发一个简单的Book增 ...

  6. MyBatis-Plus学习笔记(1):环境搭建以及基本的CRUD操作

    MyBatis-Plus是一个 MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,使用MyBatis-Plus时,不会影响原来Mybatis方式的使用. SpringBoot+M ...

  7. Oracle触发器实现监控某表的CRUD操作

    前提:请用sys用户dba权限登录 1.创建一个表来存储操作日志 create table trig_sql( LT DATE not null primary key, SID NUMBER, SE ...

  8. 通过jdbc完成单表的curd操作以及对JDBCUtils的封装

    概述:jdbc是oracle公司制定的一套规范(一套接口),驱动是jdbc的实现类,由数据库厂商提供.所以我们可以通过一套规范实现对不同的数据库操作(多态) jdbc的作用:连接数据库,发送sql语句 ...

  9. JDBC简单增删改查实现(单表)

    0.准备工作 开发工具: MySQL数据库, intelliJ IDEA2017. 准备jar包: mysql-connector-java-5.1.28-bin.jar(其他均可) 1. 数据库数据 ...

随机推荐

  1. 问题:CMD安装mysql-server遇到找不到MSVCR120.dll问题(已解决)

    今天,我用CMD安装mysql服务器端遇到了找不到msvcr120.dll问题,所以我去网上下载这个dll,但是出现找不到入口,或者什么的.  我想了想,去下载运行时库(因为MSVCR是Microso ...

  2. python全栈开发 * 继承性 层叠性 盒模型 标准文档流 * 180809

    ---恢复内容开始--- 一继承性 1.继承: 给父级设置一些属性,子级继承了父级的该属性,这就是我们的css中的继承. 2. 可继承: color . font-*(size). text-*(de ...

  3. 2019.4.10 初识puppeteer

    注:原地址:https://www.cnblogs.com/paris-test/p/9705075.html 一.Puppeteer 介绍 Puppeteer 翻译是操纵木偶的人,利用这个工具,我们 ...

  4. 秒杀ecshop的前台写shell 0day

    ECSHOP号称最大的开源网店系统,官方是这样介绍它的:“ECShop网店系统是一套免费开源的网上商店软件,无论在稳定性.代码优化.运行效率.负载能力.安全等级.功能可操控性和权限严密性等方面都居国内 ...

  5. jquery $.ajax({});参数详解

    用到过的: type:请求方式,默认 GET: url:请求路径: data:请求参数,类型是String:JSON.stringify({"name":tom,"age ...

  6. Js中Map对象的使用

    Js中Map对象的使用 1.定义 键/值对的集合. 2.语法 mapObj = new Map() 3.备注 集合中的键和值可以是任何类型.如果使用现有密钥向集合添加值,则新值会替换旧值. 4.属性 ...

  7. JavaScript实现预览本地上传图片

    <html> <head> <title> www.jb51.net图片上传预览 </title> <script> function Pr ...

  8. 5.6版本GTID复制异常处理一例(转)

    http://imysql.com/2014/07/31/mysql-faq-exception-replication-with-gtid.shtml 昨天处理了一个MySQL 5.6版本下开启GT ...

  9. Tea for Mac(mac笔记软件)中文版

    为大家分享一款好用且免费的mac笔记软件,Tea for Mac提供了实时渲染的Markdown,功能全面,支持各种快捷键,使用tea mac版时,在段首打@即可快速插入图片.标题.列表等元素,非常便 ...

  10. powerdesigner的PDM模型name和comment相互复制替换

    在[Tools]-[Execute Commands]-[Edit/Run Script] 下.输入以下命令,这些命令也可以保存起来,扩展名为 vbs ,以便下次使用. 1.name的值复制到comm ...