简单的CRUD(一)
一、JDBC的概述--(来源于百度)
JDBC(Java DataBase Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。JDBC提供了一种基准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序。JDBC对Java程序员而言是API,对实现与数据库连接的服务提供商而言是接口模型。
JDBC 可做三件事:与数据库建立连接、发送操作数据库的语句并处理结果。
JDBC API提供了以下接口和类:
DriverManager: 这个类管理数据库驱动程序的列表。确定内容是否符合从Java应用程序使用的通信子协议正确的数据库驱动程序的连接请求。识别JDBC在一定子协议的第一个驱动器将被用来建立数据库连接。
Driver: 此接口处理与数据库服务器通信。很少直接直接使用驱动程序(Driver)对象,一般使用
DriverManager中的对象,它用于管理此类型的对象。它也抽象与驱动程序对象工作相关的详细信息Connection : 此接口与接触数据库的所有方法。连接对象表示通信上下文,即,与数据库中的所有的通信是通过此唯一的连接对象。
Statement : 可以使用这个接口创建的对象的SQL语句提交到数据库。一些派生的接口接受除执行存储过程的参数。
ResultSet: 这些对象保存从数据库后,执行使用
Statement对象的SQL查询中检索数据。它作为一个迭代器,可以通过移动它来检索下一个数据。SQLException: 这个类用于处理发生在数据库应用程序中的任何错误。
二、CRUD
crud是指在做计算处理时的增加(Create)、读取查询(Retrieve)、更新(Update)和删除(Delete)几个单词的首字母简写。
crud主要被用在描述软件系统中数据库或者持久层(dao层)的基本操作功能。
三、实现简单的CRUD
1.实现条件
1、jar包, mysql-connector-java-5.1.26-bin.jar
2、数据库MySQL
2.具体代码
1.dao层接口
public interface ILoginUserDao {
/**
* 增加
* @param loginUser
*/
void save(LoginUser loginUser);
/**
* 删除
* @param id
*/
void delete(Integer id);
/**
* 更新
* @param loginUser
*/
void update(LoginUser loginUser);
/**
* 查询
* @return
*/
List query();
}
2.dao层实现
public class LoginUserDao implements ILoginUserDao {
@Override
public void save(LoginUser loginUser) {
System.out.println("----save----");
// 首先加载jdbc实现类
try {
// 1.加载驱动
Class.forName("com.mysql.jdbc.Driver");
// 2.创建链接
Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/user", "root", "admin");
// 3.创建编译语句
Statement statement = connection.createStatement();
// 4.执行sql语句
String sql = "INSERT INTO loginuser(username, password) VALUES ('王五', '6666')";
int i = statement.executeUpdate(sql);
// 5.释放资源
statement.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
@Override
public void delete(Integer id) {
System.out.println("----delete----");
try {
// 1.加载驱动
Class.forName("com.mysql.jdbc.Driver");
// 2.创建链接
Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/user", "root", "admin");
// 3.创建编译语句
Statement statement = connection.createStatement();
// 4.执行语句
String sql = "DELETE FROM loginuser WHERE id = 2";
int i = statement.executeUpdate(sql);
// 5.释放资源
statement.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
@Override
public void update(LoginUser loginUser) {
System.out.println("----update----");
try {
// 1.加载驱动
Class.forName("com.mysql.jdbc.Driver");
// 2.创建链接
Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/user", "root", "admin");
// 3.创建编译语句
Statement statement = connection.createStatement();
// 4.执行sql语句
String sql = "UPDATE loginuser SET username = '王五', password = '55555' WHERE id = 1";
int i = statement.executeUpdate(sql);
// 5.释放资源
statement.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
@Override
public List query() {
System.out.println("----query----");
// new一个list集合对象
List<LoginUser> list = new ArrayList<>();
try {
// 1.加载驱动
Class.forName("com.mysql.jdbc.Driver");
// 2.创建链接
Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/user", "root", "admin");
// 3.创建编译语句
Statement statement = connection.createStatement();
// 4.执行sql语句
String sql = "SELECT id, username, password FROM loginuser WHERE id > 4";
ResultSet resultSet = statement.executeQuery(sql);
// 取出查询内容
while (resultSet.next()) {
String username = resultSet.getString("username");
String password = resultSet.getString("password");
// 创建LoginUser对象
LoginUser loginUser = new LoginUser();
loginUser.setUsername(username);
loginUser.setPassword(password);
// 添加到集合
list.add(loginUser);
}
// 5.释放资源
resultSet.close();
statement.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
return list;
}
}
3.注意事项
1、使用DriverManager获取连接.
Connection conn = DriverManager.getConnection(String url,String user,String password);
2、增加、删除、修改执行sql语句 statement.executeUpdate(sql) 使用的是 executeUpdate;
而查询使用的是 executeQuery ==》ResultSet resultSet = statement.executeQuery(sql);
简单的CRUD(一)的更多相关文章
- 8天掌握EF的Code First开发系列之2 简单的CRUD操作
本文出自8天掌握EF的Code First开发系列,经过自己的实践整理出来. 本篇目录 创建控制台项目 根据.Net中的类来创建数据库 简单的CRUD操作 数据库模式更改介绍 本章小结 本人的实验环境 ...
- spring集成mongodb封装的简单的CRUD
1.什么是mongodb MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. mongoDB MongoDB是一个介 ...
- Mongodb系列- java客户端简单使用(CRUD)
Mongodb提供了很多的客户端: shell,python, java, node.js...等等. 以 java 为例实现简单的增删改查 pom文件: <dependencies> & ...
- springboot + mybatis 的项目,实现简单的CRUD
以前都是用Springboot+jdbcTemplate实现CRUD 但是趋势是用mybatis,今天稍微修改,创建springboot + mybatis 的项目,实现简单的CRUD 上图是项目的 ...
- 【SSH三大框架】Hibernate基础第五篇:利用Hibernate完毕简单的CRUD操作
这里利用Hibernate操作数据库完毕简单的CRUD操作. 首先,我们须要先写一个javabean: package cn.itcast.domain; import java.util.Date; ...
- 简单的CRUD(二)
一.重构简单的CRUD 1.JDBC工具类 1.因为在crud中都包含一些相同的代码所以可以提取出来,抽取代码重构为工具类. 2.将工具类设置为static静态类,方便调用,不需要new对象. pub ...
- Springboot项目搭建(1)-创建,整合mysql/oracle,druid配置,简单的CRUD
源码地址:https://github.com/VioletSY/article-base 1:创建一个基本项目:https://blog.csdn.net/mousede/article/detai ...
- ASP.NET Core MVC+Layui使用EF Core连接MySQL执行简单的CRUD操作
前言: 本章主要通过一个完整的示例讲解ASP.NET Core MVC+EF Core对MySQL数据库进行简单的CRUD操作,希望能够为刚入门.NET Core的小伙伴们提供一个完整的参考实例.关于 ...
- Mybatis实现简单的CRUD(增删改查)原理及实例分析
Mybatis实现简单的CRUD(增删改查) 用到的数据库: CREATE DATABASE `mybatis`; USE `mybatis`; DROP TABLE IF EXISTS `user` ...
随机推荐
- [AGC006E] Rotate 3x3 树状数组+贪心
Description XFZ在北京一环内有一套房. XFZ房子的地砖呈网格状分布,是一个3∗N3∗N的网格.XFZ在买下这套房时,每个地砖上有一个数字,位置为(i,j)(i,j)的地砖上的数 ...
- 【lojg152】 乘法逆元 2(数学)
题面 传送门 题解 orz Wa自动机 这是一个可以\(O(n)\)求出\(n\)个数逆元的方案 先把所有的数做一个前缀积,记为\(s_i\) 然后我们用快速幂求出\(s_n\)的逆元,记为\(sv_ ...
- UML图基础
UML(Unified Model Language)统一建模语言,是对象管理组织(OMG)制定的一个通用的.可视化的建模标准语言,可以用来可视化.描述.构造和文档化软件密集型系统的各种工作.在学习设 ...
- ES6(二) 函数
箭头函数 是简写,不要function 1.如果有且仅有一个参数,()可以不写 2.如果有且仅有一条语句,而且是return,{}也可以不写 let arr=[12,23,5,6] // arr.so ...
- springboot设置日志级别时报错
配置springboot日志,输出级别为info,运行时报错: Caused by: org.springframework.boot.context.properties.bind.BindExce ...
- 移动端尺寸新写法-rem
rem这是个低调的css单位,近一两年开始崭露头角,有许多同学对rem的评价不一,有的在尝试使用,有的在使用过程中遇到坑就弃用了.但是我对rem综合评价是用来做web app它绝对是最合适的人选之一. ...
- sql2008R2新建链接服务器。
1:用sql新建链接服务器对象: /****** Object: LinkedServer [pad] Script Date: 10/23/2018 15:47:45 ******/ EXEC ma ...
- Java转python第二天
1.dict基本操作 dic = {"name":"张三","age":21} # 增 dic['high'] = 185 # 增加 ,结果 ...
- java se系列(十二)集合
1.集合 1.1.什么是集合 存储对象的容器,面向对象语言对事物的体现,都是以对象的形式来体现的,所以为了方便对多个对象的操作,存储对象,集合是存储对象最常用的一种方式.集合的出现就是为了持有对象.集 ...
- 构建私有Docker Registry
1.设置insecure-registry: 可能会出现无法push镜像到私有仓库的问题. 这是因为我们启动的registry服务不是安全可信赖的. 1) sudo vim /etc/default/ ...