简单的Java代码连接数据库实现增删改查

首先创建一个数据库,创建一个表

例如下图这样的



建立一个实体类

1.一般情况会与数据库中表内的数据类型一致

2. 建议:成员变量的名字要和数据库里面的字段名一致

3. 建议:使用基本数据类型的包装类

代码如下:

package a_preparedstatement;

public class Person {

private Integer id;

private String name;

        private Integer age;

        public Integer getId() {

        return id;

}

public void setId(Integer id) {

    this.id = id;

}

public String getName() {

    return name;

}

public void setName(String name) {

    this.name = name;

}

public Integer getAge() {

    return age;

}

public void setAge(Integer age) {

    this.age = age;

}

@Override

public String toString() {

    return "Person [id=" + id + ", name=" + name + ", age=" + age + "]";

}

}



然后在创建个java文件写增删改查的方法

package a_preparedstatement;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.util.ArrayList;

import java.util.List;

import utils.JDBCUtil;

public class PersonDao {

/* 使用PreparedStatement 增删改查 *//** * 出入一个Person类对象,保存数据到数据库中 * @param person * @return int类型,返回值大于0表示添加成功,返回0表示添加数据失败 */

public int add(Person person) {

Connection conn = null;

PreparedStatement statement = null;

try {conn = JDBCUtil.getConnection();

String sql = "insert into person(name, age) values(?,?)";

//预处理SQL语句,获取到PreparedStatementstatement = conn.prepareStatement(sql);

//给予参数statement.setString(1, person.getName());statement.setInt(2, person.getAge());

//执行SQL语句return statement.executeUpdate();

} catch (SQLException e) {

// TODO: handle exceptione.printStackTrace();

}

 finally {

JDBCUtil.close(conn, statement);

}

return 0;

}

/** * 更具ID删除数据库里面的数据 * @param id * @return int类型,返回值大于0表示删除成功,返回0表示删除数据失败 */

public int deleteById(int id) {

Connection conn = null;

PreparedStatement statement = null;

try {

conn = JDBCUtil.getConnection();

String sql = "delete from person where id = ?";statement = conn.prepareStatement(sql);statement.setInt(1, id);

return statement.executeUpdate();

} catch (SQLException e) {

// TODO: handle exceptione.printStackTrace();

} finally {

JDBCUtil.close(conn, statement);}return 0;}

/** * 修改Person的个人信息 * @param person 传入的Person类对象 * @return int类型,返回值大于0表示修改成功,返回0表示修改数据失败 */

public int update(Person person) {

Connection conn = null;

PreparedStatement statement = null;

try {

conn = JDBCUtil.getConnection();

String sql = "update person set name=?, age=? where id=?";

statement = conn.prepareStatement(sql);

statement.setString(1, person.getName());

statement.setInt(2, person.getAge());

statement.setInt(3, person.getId());

return statement.executeUpdate();

} catch (SQLException e) {

// TODO: handle exception}

 finally {

}

return 0;

}

 /** * 查询数据库里面的所有的Person信息,返回一个List集合 * @return 返回保存Person类对象的List集合 */

public ListfindAll() {

ResultSet set = null;

Connection conn = null;

PreparedStatement statement = null;

Listlist = new ArrayList();

try {

conn = JDBCUtil.getConnection();

String sql = "select * from person";

statement = conn.prepareStatement(sql);

set = statement.executeQuery();

while (set.next()) {

Person p = new Person();

p.setId(set.getInt("id"));

p.setName(set.getString("name"));

p.setAge(set.getInt("age"));

list.add(p);

}

return list;

} catch (Exception e) {

// TODO: handle exception

} finally {

JDBCUtil.close(conn, statement, set);

}

return null;

}

/**

* 根据ID 查询数据库中的Person信息,返回一个Person类对象

* @param id 要查询的PersonID

* @return 返回一个Person类对象,如果没有找到,返回null

*/

public Person findById(int id) {

ResultSet set = null;

Connection conn = null;

PreparedStatement statement = null;

Person p = null;

try {

conn = JDBCUtil.getConnection();

String sql = "select * from person where id=?";

statement = conn.prepareStatement(sql);

statement.setInt(1, id);

set = statement.executeQuery();

if (set.next()) {

p = new Person();

p.setId(set.getInt("id"));

p.setName(set.getString("name"));

p.setAge(set.getInt("age"));

}

return p;

} catch (Exception e) {

// TODO: handle exception

} finally {

JDBCUtil.close(conn, statement, set);

}

return null;

}

}



最后写个视图层,也就是页面,在控制台显示的

package a_preparedstatement;

import java.util.Scanner;

public class ViewDemo01 {

public static void main(String[] args) {

PersonDao pd = new PersonDao();

Scanner sc = new Scanner(System.in);

while(true) {

System.out.println("###############");

System.out.println("1.添加数据");

System.out.println("2.删除数据");

System.out.println("3.更新数据");

System.out.println("4.查看所有数据");

System.out.println("5.查询指定数据");

System.out.println("6.退出");

System.out.println("¥¥¥¥¥¥¥¥¥¥¥¥");

System.out.println("###############");

int choose = sc.nextInt();

switch (choose) {

case 1:

System.out.println("请输入姓名");

String name = sc.nextLine();

System.out.println("请输入年龄");

int age = sc.nextInt();

Person p = new Person();

p.setName(name);

p.setAge(age);

pd.add(p);

break;

case 2 :

System.out.println("请输入要删除的id");

int id = sc.nextInt();

pd.deleteById(id);

break;

case 3:

System.out.println("请输入姓名");

String name1 = sc.nextLine();

System.out.println("请输入年龄");

int age1 = sc.nextInt();

Person p2 = new Person();

p2.setName(name1);

p2.setAge(age1);

pd.update(p2);

break;

case 4:

pd.findAll();

break;

case 5:

System.out.println("请输入要查看的人的id");

id = sc.nextInt();

pd.findById(id);

break;

case 6:

System.out.println("退出程序");

System.exit(0);

break;

default:

break;

}

}

}

}

这样就好了

主要掌握SQL语句

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 210,978评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 89,954评论 2 384
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,623评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,324评论 1 282
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,390评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,741评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,892评论 3 405
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,655评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,104评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,451评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,569评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,254评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,834评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,725评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,950评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,260评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,446评论 2 348

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,597评论 18 399
  • 本人的环境为Myeclipse10、MySQL5.7.15 本文包括:简介JDBC编程步骤打通数据库程序详解—Dr...
    廖少少阅读 3,932评论 7 39
  • 一. Java基础部分.................................................
    wy_sure阅读 3,805评论 0 11
  • JDBC简介 SUN公司为了简化、统一对数据库的操作,定义了一套Java操作数据库的规范,称之为JDBC。JDBC...
    奋斗的老王阅读 1,507评论 0 51
  • 最近能不看完不罢休的书,除了《三体》、《跃迁》以外,就是这一本《查令十字街84号》了。 在书信交流的年代,人们通过...
    Jeffrey_l阅读 173评论 0 1