JDBC完成增加-修改-增加-查询
JDBC的基本使用流程:
增加
1 导入jar包:
导入ojdbc6.jar,在项目上右键 builder path-->add to builder path.
2 加载驱动
Class.forName("oracle.jdbc.driver.OracleDriver");
作用:初始化加载jdbc类到java虚拟机.
注意:
ojdbc6.jar使用此包该句可以省略不写.
3 获取数据库连接对象
Connection conn =DriverMananger.getConnection("url","username","password");
参数含义:
url:表示要连接的数据地址
username:数据库的用户名
password:数据库的密码
作用:
连接到指定的数据库并返回连接对象.
4 创建sql命令对象
Statement stmt=conn.createStatement();
作用:
编译,发送SQL命令
5 创建sql命令
String sql="insert into dept values(92,'','')";
6 执行sql命令:
新增sql命令:
int i=stmt.executeUpdate(sql);
返回值:
返回值如果小于0,表示未执行成功
返回值如果大于0,表示成功修改的数据量.
7 关闭资源
------------------------------------------------------------------------------------------------------------------------------------------
* 常见的jdbc错误:
* a ClassNotFoundException:
* 驱动类未找到.
* b java.sql.SQLException: No suitable driver found for :thin:@localhost:1521:orcl
* URL错误
* c java.sql.SQLException: ORA-01017: invalid username/password; logon denied
* 用户 名或密码错误
* d java.sql.SQLSyntaxErrorException: ORA-00900: 无效 SQL 语句
* Sql语句错误
* e java.sql.SQLIntegrityConstraintViolationException: ORA-00001: 违反唯一约束条件 (SCOTT.PK_DEPT)
* 主键冲突
---------------------------------------------------------------------------------------------------------------------------------------------
JDBC新增代码:
public class TestInsert1 {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
//1 加载驱动类
//Class.forName("oracle.jdbc.driver.OracleDriver");
//2 获取数据库连接对象(连接指定的数据库)
Connection conn=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl","scott","oracle");
//3 获取sql命令对象(编译和发送sql命令给数据库)
Statement stmt=conn.createStatement();
//4 创建sql命令
String sql="insert into dept values(92,'吃鸡学院','北京')";
//5 指定sql命令
int i=stmt.executeUpdate(sql);
System.out.println("执行结果:"+i);
//6 关闭资源
stmt.close();
conn.close();
}
}
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
JDBC代码完善(全)
public class TestInsert2 {
public static void main(String[] args){
//声明jdbc变量
Connection conn=null;
Statement stmt=null;
//声明JDBC参数
String driver="oracle.jdbc.driver.OracleDriver";
String url="jdbc:oracle:thin:@localhost:1521:orcl";
String username="scott";
String password="oracle";
//1 加载驱动类
try {
Class.forName(driver);
//2 获取数据库连接对象(连接指定的数据库)
conn=DriverManager.getConnection(url,username,password);
//3 获取sql命令对象(编译和发送sql命令给数据库)
stmt=conn.createStatement();
//4 创建sql命令
String sql="insert into dept values(97,'吃鸡学院','北京')";
//5 指定sql命令
int i=stmt.executeUpdate(sql);
System.out.println("执行结果:"+i);
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
//6 关闭资源
try {
stmt.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
修改
使用流程不变:
导入jar包
加载驱动
创建连接对象
创建sql命名对象
创建sql命令
执行sql命令
关闭资源
-----------------------------------------------------------------------------------
更新和新增比较除了SQL语句不通以外,代码基本一致:
public class TestUpdate {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
//1加载驱动
Class.forName("oracle.jdbc.driver.OracleDriver");
//2创建连接对象
Connection conn=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl", "scott","oracle");
//3创建sql命令对象
Statement stmt=conn.createStatement();
//4创建sql命令
String sname="张三三";
String sql="update student set sname='"+sname+"' where snum=2";
//5执行sql命令
int i=stmt.executeUpdate(sql);
System.out.println(i);
//6关闭资源
stmt.close();
conn.close();
}
}
删除:
加载jar包
加载驱动
创建连接对象
创建sql命令对象
创建sql命令(删除)
执行sql命令
关闭资源
-------------------------------------------------------------------------------------
JDBC中的增加删除修改除了SQL语句不同以外,基本一致:
public class TestDel {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
//1 加载驱动
Class.forName("oracle.jdbc.driver.OracleDriver");
//2创建连接对象
Connection conn=DriverManager.getConnection("jdbc:oracle:thin:@LocalHost:1521:orcl", "scott", "oracle");
//3创建sql命令对象
Statement stmt=conn.createStatement();
//4创建sql命令
String sql="delete from student where snum='2'";
//5执行sql命令
int i=stmt.executeUpdate(sql);
System.out.println("删除数据量:"+i);
//6关闭资源
stmt.close();
conn.close();
}
}
------------------------------------------------------------------------------------
JDBC完成查询:
基本流程:
声明ArrayList集合
加载驱动
创建连接对象
创建sql命令对象
创建sql命令
执行sql命令
遍历查询结果,并将结果存储到ArrayList中
关闭资源
----------------------------------------------------------------------------------------------
JDBC查询示例代码:
package com.bjsxt.test;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import com.bjsxt.daoImpl.StudentDaoImpl;
import com.bjsxt.pojo.Student;
/**
* JDBC的查询:
* 加载驱动
* 创建连接对象
* 创建sql命令对象
* 创建sql命令
* 执行sql命令
* 返回存储了查询到的数据的对象(ResultSet)
* ResultSet对象是基于指针进行数据存储的,类似枚举.
* 关闭资源
* 问题:
* 查询的返回值类型是ResultSet,是基于指针进行数据存储的,不便于数据的针对性的获取.
* 解决:
* 将数据转换到ArrayList中进行存储.
* 使用:
* 创建和表结构相同的实体类进行单条数据的存储(一条数据就是一个实例化对象)
* 将对象存储到ArrayList中.
* 快速获取返回值:
* alt+shift+L
*
* @author MyPC
*
*/
public class TestSelect {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
//声明List集合
ArrayList<Student> list=new ArrayList<>();
//加载驱动
Class.forName("oracle.jdbc.driver.OracleDriver");
//创建连接对象
Connection conn=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl","scott","oracle");
//创建sql命令对象
Statement stmt=conn.createStatement();
//创建Sql命令
String sql="select * from student";
//执行Sql命令
ResultSet rs = stmt.executeQuery(sql);
while(rs.next()){
//创建学生对象
Student stu=new Student();
stu.setSnum(rs.getInt("snum"));
stu.setSname(rs.getString("sname"));
stu.setSage(rs.getInt("sage"));
stu.setMoney(rs.getDouble("money"));
//将对象存储到ArrayList中
list.add(stu);
}
System.out.println(list.get(2));
//创建DaoImpl层对象
StudentDaoImpl sd=new StudentDaoImpl();
ArrayList<Student> ls=sd.getStudentInfo();
}
}
JDBC完成增加-修改-增加-查询的更多相关文章
- ado.net c#基本的增加,修改,删除,查询
自己初次学习用的,各种不规范,注释没写 class AdoDemo { static string strConn = @"Data Source=server1;Initial Catal ...
- 使用JDBC获取能自动增加的主键
本篇讲述如何使用JDBC获取能自动增加的主键的值.有时候我们在向数据库插入数据时希望能返回主键的值,而不是通过查询的方式.一般来说,在多表相互关联主键约束,也就是说别的表的外键约束是该表的主键,那么在 ...
- Android webview中cookie增加/修改
最近项目需求中,需要满足往webview传递cookie,而且cookie需要增加修改: public class MainActivity extends Activity { private We ...
- Oracle 增加修改删除字段
Oracle 增加修改删除字段 添加字段的语法:alter table tablename add (column datatype [default value][null/not null],…. ...
- 用dom4j修改xml(增加修改节点)
用dom4j修改xml(增加修改节点) 博客分类: Java XMLJavaMyeclipseServlet 使用dom4j修改解析xml,xml文件的位置是配置在xml.properties文件中 ...
- 【ES】Java High Level REST Client 使用示例(增加修改)
ES提供了多种编程语言的链接方式,有Java API,PHP API,.NET API 官网可以详细了解 https://www.elastic.co/guide/en/elasticsearch/c ...
- sql 增加修改表格属性字段
1.修改字段默认值 alter table 表名 drop constraint 约束名字 ------注解:删除表的字段的原有约束 alter table 表名 add constraint 约束名 ...
- cogs 1316. 数列操作B 区间修改 单点查询
1316. 数列操作B ★★ 输入文件:shulieb.in 输出文件:shulieb.out 简单对比时间限制:1 s 内存限制:128 MB [问题描述] 假设有一个大小为 n(n ...
- ASP.NET MVC搭建项目后台UI框架—6、客户管理(添加、修改、查询、分页)
目录 ASP.NET MVC搭建项目后台UI框架—1.后台主框架 ASP.NET MVC搭建项目后台UI框架—2.菜单特效 ASP.NET MVC搭建项目后台UI框架—3.面板折叠和展开 ASP.NE ...
随机推荐
- django项目搭建及Session使用
django+session+中间件 一.使用命令行创建django项目 在指定路径下创建django项目 django-admin startproject djangocommon 在项目目录 ...
- Redis清理
Redis登录: Redis目录: redis-cli.exe -h 127.0.0.1 -p 6739 login: auth “password” flushall
- Python下Pip的安装【get-pip】
1.下载 下载https://bootstrap.pypa.io/get-pip.py 如果不能下载,可下载:http://files.cnblogs.com/files/zhangzhiming/g ...
- Mysql中自定义函数编程
1.语法 1.1 新建函数 Create function function_name(参数列表) returns 返回值类型 函数体 (1)函数名,应该合法的标识符,并且不应该与已有的关键字冲突. ...
- 1.spark的wordcount解析
一.Eclipse(scala IDE)开发local和cluster (一). 配置开发环境 要在本地安装好java和scala. 由于spark1.6需要scala 2.10.X版本的.推荐 2 ...
- centos环境下如何导出数据库
MySQL数据库的导入导出可以用数据库备份工具mysqldump mysqldump工具是mysql自带的一个非常方便的一款小工具,存在mysql安装目录的/usr/local/mysql/bin ( ...
- [operator]jenkins+gitlab/Webhook自动构建发布
开发同事在提交代码到gitlab后,需要使用jenkins对代码进行构建,每次都需要手动操作会很繁琐,如果工程很大,那么也会浪费时间,gitlab的webhook功能,可以在代码提交后自动调用jenk ...
- CodeForces 342C Cupboard and Balloons (几何问题)
题意:给定一个 r 和 h,r 是上面那个半球的半径,h 是下面那个圆柱的高度,然后有一些半径为 r/2的气球,问你最多能放几个. 析:根据题意,很容易知道,先从下面往上放,两个两个的放,放到不能放的 ...
- css3系列之animation
在上次博文中已经讲了transition,其实animation与transition功能相同,都是通过改变元素 的属性来实现动画效果的.但是它们也有区别:transition是只能通过改变指定属性的 ...
- 编写高质量代码改善C#程序的157个建议——建议94:区别对待override和new
建议94:区别对待override和new override和new使类型体系应为继承而呈现出多态性.多态要求子类具有与基类同名的方法,override和new的作用就是: 如果子类中的方法前面带有n ...