Java 第27章 JDBC
JDBC 模版
JDBC 的工作原理
JDBC API
提供者:Sun公司
内容:供程序员调用的接口与类,集成在java.sql 和javax.sql 包中,如:
DriverManager 类
Connection 接口
PreparedStatement 接口
ResultSet 接口
DriverManager
提供者:Sun公司
作用:管理各种不同的JDBC 驱动
JDBC 驱动
提供者:数据库厂商
作用:负责连接各种不同的数据库
java 应用程序
JDBC API
JDBC Driver Manager
JDBC 驱动 --->sql server JDBC 驱动 ----> oracle
JDBC API
JDBC API 主要功能:与数据库建立连接、执行SQL 语句、处理结果
1、DriverManager
2、Connection
3、Statement
4、ResultSet ---> 4个步骤 !
DriverManager :依据数据库的不同,管理JDBC驱动
Connection :负责连接数据库并担任传送数据的任务
PreparedStatement:由 Connection 产生、负责执行SQL语句
ResultSet:负责保存Statement执行后所产生的查询结果
try {
class.forName( JDBC 驱动类);
1、加载JDBC 驱动
Class. forName("com.mysql.jdbc.Driver");
2、与数据库建立连接
connection con=DriverManager.getConnection(URL,数据库用户名,密码);
//URL 用来标识数据库
PreparedStatement pstmt=con.PreparedStatement("查询sql语句");
ResultSet rs=pstmt.executeQuery();
//执行SQL语句,并得到返回结果
while (rs.next()){
int x=rs.getint("a");
String s=rs.getString("b");
float f=rs.getFloat("c");
// 处理放回结果
}
rs.close();
pstmt.close();
con.close(); //关闭连接
//释放资源
}
package com.test;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Scanner;
public class Test1 {
/**
* @param args
*/
public static void main(String[] args) {
Connection conn=null;
PreparedStatement pstmt=null;
ResultSet rst=null;
try {
//1、加载驱动
Class.forName("com.mysql.jdbc.Driver");
//2、建立连接
conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/nyschool?CharacterEncoding=UTF-8","root","root");
//System.out.println("建立连接成功!!");
//3、创建 prepareStatement 接口并编译 sql语句
//pstmt=conn.prepareStatement("select * from student");
//执行删除
Scanner input=new Scanner(System.in);
//System.out.print("请输入要删除的学生学号:");
//int stuNo=input.nextInt();
//两种方法:
//方法1:String sql="DELETE FROM student WHERE stuNo="+stuNo;
//方法2:String sql="DELETE FROM student WHERE stuNo=7";
//执行添加
System.out.print("请输入添加的学员的编号:");
int stuNo=input.nextInt();
System.out.print("请输入添加学员的性别:");
String name=input.next();
System.out.print("请输入添加的地址:");
String phone=input.next();
//
String sql="INSERT INTO student VALUES (?,'a2323','qq',?,1,?,'江西南昌',SYSDATE(),'qq.com')";
pstmt=conn.prepareStatement(sql); //预编译方式
//给占位符赋值
pstmt.setInt(1, stuNo);
pstmt.setString(2, name);
pstmt.setString(3, phone);
System.out.print("sql:"+sql);
//4、执行SQL语句,并得到返回结果
//rst=pstmt.executeQuery(); //执行查询
int num=pstmt.executeUpdate(); //执行增删改
//5、处理返回结果
if(num>0){
System.out.println("\n添加成功!");
}else{
System.out.println("\n添加失败!");
}
while (rs.next()){
int x=rs.getint("a");
String s=rs.getString("b");
float f=rs.getFloat("c");
// 处理放回结果
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Java 第27章 JDBC的更多相关文章
- Java开发工程师(Web方向) - 03.数据库开发 - 第1章.JDBC
第1章--JDBC JDBC基础 通过Java Database Connectivity可以实现Java程序对后端数据库的访问 一个完整的数据库部署架构,通常是由客户端和服务器端两部分组成 客户端封 ...
- JAVA / MySql 编程——第七章 JDBC
1.JDBC:JDBA是Java数据库连接(Java DataBase Connectivity)技术的简称,提供连接各种常用数据库的能力: ●Java是通过JDBC技术实现对各种数据 ...
- Java面向对象笔记 • 【第9章 JDBC编程】
全部章节 >>>> 本章目录 9.1 JDBC基础 9.1.1 JDBC简介 9.1.2 JDBC常用API简介 JDBC 常用API功能说明 9.1.3 JDBC编程步骤 ...
- Java中的事务——JDBC事务和JTA事务
Java中的事务——JDBC事务和JTA事务 转载:http://www.hollischuang.com/archives/1658 之前的事务介绍基本都是数据库层面的事务,本文来介绍一下J2EE中 ...
- 第六章 JDBC
第一章 JDBC 一.JDBC的简介 1.什么是JDBC JDBC是java数据库连接(java database connectivity)技术的简称,它充当了java应用程序与各个不同数据库之间进 ...
- Java基础-面向接口编程-JDBC详解
Java基础-面向接口编程-JDBC详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.JDBC概念和数据库驱动程序 JDBC(Java Data Base Connectiv ...
- Java应用程序连接数据库--JDBC基础
Java应用程序连接数据库--JDBC基础 Java应用程序连接数据库–JDBC基础 <!-- MySQL驱动,连接数据库用,由数据库厂商提供 --> <dependency&g ...
- java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver 错误的解决办法
java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver 错误的解决办法 (2011-05-05 16:08:05) 转载▼ ...
- 【ASP.NET MVC 5】第27章 Web API与单页应用程序
注:<精通ASP.NET MVC 3框架>受到了出版社和广大读者的充分肯定,这让本人深感欣慰.目前该书的第4版不日即将出版,现在又已开始第5版的翻译,这里先贴出该书的最后一章译稿,仅供大家 ...
随机推荐
- nagios二次开发(六)---nagiosql原理及主要文件的介绍
nagiosql的入口文件:index.php,这也是所有php程序的入口文件.是由apache指定的. index.php 文件的开始引入了 require("functions/prep ...
- Android_SQLite版本升级,降级 管理
今天我们主要学习了数据库版本升级对软件的管理操作. 我们手机经常会收到xxx软件升级什么的提醒,你的软件版本更新,同时你的数据库对应的版本也要相应的更新. 数据库版本更新需要主要的问题: 软件的1.0 ...
- oracle 字符串
oracle获取字符串长度函数length()和hengthb() lengthb(string)计算string所占的字节长度:返回字符串的长度,单位是字节 length(string)计算stri ...
- 图解直方图均衡化及其Python实现
在理解直方图均衡化的过程中,参考了一些书籍和博客,让人困惑的是,笔者对于直方图的理解还是停留在表面,并没有深入理解其内涵.因此,本文拟结合图片对直方图的概念进行阐述,并给出其Python实现,最后对她 ...
- 【Android端 APP 启动时长获取】启动时长获取方案及具体实施
一.什么是启动时长? 1.启动时长一般包括三种场景,分别是:新装包的首次启动时长,冷启动时长.热启动时长 冷启动 和 热启动 : (1)冷启动:当启动应用时,后台没有该程序的进程,此时启动的话系统会分 ...
- maven 编译项目时:报com.sun.image.codec.jpeg不存在
项目中用到图片处理相关的一些工具类,在eclipse开发工具内,程序并没有什么问题,都可以正常使用,项目也没有报错,但通过maven 进行编译打包时,则会报错: 程序包com.sun.image.co ...
- C语言字符串拷贝
C语言字符串拷贝利用指针操作,要清楚知道指针的指向 代码如下: #include <stdio.h> #include <assert.h> #include <stri ...
- [题解]codevs1001 舒适的路线
h3 { font-family: Consolas; color: #339966 } .math { font-family: Consolas; color: gray } 题目描述 Descr ...
- Android SVN的配置
关于svn有不错的图文博文,先po一个个人认为很不错的博文:http://ask.android-studio.org/?/article/97 接下来呢呢就是以我个人的思维模式来讲解svn啦: 当然 ...
- android:digits属性
android:digits属性限定输入的字符 可以用于密码输入等输入框 ex: 个人意见: 但是这样的话不符合要求的字符直接输入不上去,可能会给用户造成困惑,最好给出提示或用其他工具. 本文欢迎转载 ...