JDBC编程理论知识(1)
1.SUN公司为统一对数据库的操作,定义了一套Java操作数据库的规范,称之为JDBC
2.JDBC全称为:Java Data Base Connectivity(java数据库连接),它主要由接口组成。
组成JDBC的2个包:
(1)java.sql.*;
(2)javax.sql.*;
3.JDBC在程序中的位置:
4.JDBC的六个固定步骤
1。注冊数据库驱动[利用反射]
2。取得数据库连接对象Connection
3。创建SQL对象
4。运行SQL命令,并返回结果集
5。处理结果集
6,依次关闭结果集
5.JDBC的DriverManager对象:
(1).Jdbc程序中的DriverManager用于载入驱动,并创建与数据库的链接。这个API的经常用法:DriverManager.registerDriver(new Driver())。注意:在实际开发中,并不推荐採用这种方法注冊驱动。查看Driver的源码能够看到。假设採用此种方式,会导致驱动程序载入两次,也就是在内存中会有两个Driver对象。
java.sql.Driver(接口)-com.mysql.jdbc.Driver(实现类)
(首先返回true)boolean acceptsURL(String url)
查询驱动程序是否觉得它能够打开到给定 URL 的连接。
(然后)Connection connect(String url, Properties info)
试图创建一个到给定 URL 的数据库连接。
(2).推荐方式:Class.forName(“com.mysql.jdbc.Driver”);採用此种方式不会导致驱动对象在内存中反复出现,而且採用此种方式,程序只只须要一个字符串,不须要import驱动的API。这样可使程序不依赖详细的驱动,使程序的灵活性更高。
DriverManager.getConnection(url, user, password),依据url获取数据库的链接。
6.数据库的URL
URL用于标识数据库的位置。程序猿通过URL地址告诉JDBC程序连接哪个数据库,
(1).经常使用数据库URL地址的写法:
Oracle—jdbc:oracle:thin:@localhost:1521:sid
SqlServer—jdbc:microsoft:sqlserver://localhost:1433; DatabaseName=sid
MySql—jdbc:mysql://localhost:3306/sid
(2).Mysql的url地址的简写形式: jdbc:mysql:///sid
7.JDBC的Connection对象:
Jdbc程序中的Connection。它用于代表数据库的链接,Collection是数据库编程中最重要的一个对象,client与数据库全部交互都是通过connection对象完毕的,这个对象的经常用法:
createStatement():创建向数据库发送sql的statement对象。
prepareStatement(sql) :创建向数据库发送预编译sql的PrepareSatement对象。
prepareCall(sql):创建运行存储过程的callableStatement对象。
setAutoCommit(boolean autoCommit):设置事务是否自己主动提交。
commit() :在链接上提交事务。
rollback() :在此链接上回滚事务。
8.JDBC的statement:
Jdbc程序中的Statement对象用于向数据库发送SQL语句。 Statement对象经常用法:
execute(String sql):用于向数据库发送随意sql语句
executeQuery(String sql) :仅仅能向数据发送select语句。
executeUpdate(String sql):仅仅能向数据库发送insert、update或delete语句
addBatch(String sql) :把多条sql语句放到一个批处理中。
executeBatch():向数据库发送一批sql语句运行。
clearBatch():清空缓冲
9.JDBC的ResultSet对象:
Jdbc程序中的ResultSet用于代表Sql语句的运行结果。
Resultset封装运行结果时。採用的类似于表格的方式。ResultSet 对象维护了一个指向表格数据行的游标。初始的时候,游标在第一行之前,调用ResultSet.next() 方法,能够使游标指向详细的数据行。进行调用方法获取该行的数据。
(1)ResultSet既然用于封装运行结果的,所以该对象提供的都是用于获取数据的get方法:
获取随意类型的数据
getObject(int index)
getObject(string columnName)
获取指定类型的数据,比如:
getString(int index)
getString(String columnName)
(2).ResultSet还提供了对结果集进行滚动的方法:
next():移动到下一行
previous():移动到前一行
absolute(int row):移动到指定行
beforeFirst():移动resultSet的最前面。
afterLast() :移动到resultSet的最后面。
10.MySQL和java的数据类型的转换
11.代码演示:
package cn.wwh.www.java.jdbc; import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement; /**
*类的作用:用来练习JDBC编程的,连接的数据库是MySQL
*
*
*
*
*@author 一叶扁舟
*@version 1.0
*@创建时间: 2014-8-7 下午08:28:42
*/
public class FirstJDBC {
/**
*建表语句:
drop table if exists person;
create table person(
id int primary key auto_increment,
name char(12),
password char(12),
sex char(2) );
insert into person values(1,"wuhui",123456,"男");
insert into person values(2,"一叶扁舟",123456,"男");
*/
private static String driverClass = "com.mysql.jdbc.Driver";
private static String url = "jdbc:mysql://127.0.0.1:3306/user";
private static String user = "root";
private static String password = "wwh"; public static void main(String[] args) throws Exception {
//
// 1.载入驱动
// (1).方式1:
// DriverManager.registerDriver(new Driver());
// (2).方式2:利用反射的方式
Class.forName(driverClass);
// 使用DriverManager获取数据的连接,
// 当中返回的Connection就代表java程序和数据库的连接
/**
* @param url
* jdbc:subprotocol:subname 形式的数据库 url
* @param user
* 数据库用户,连接是为该用户建立的
* @param password
* 登录数据库的密码
*/
Connection conn = DriverManager.getConnection(url, user, password); Statement statement = conn.createStatement();
String sql = "select * from person;";
// 运行SQL命令,并返回符合条件的记录集合
ResultSet result = statement.executeQuery(sql);
// 採用两种方式接受查询的结果
while (result.next()) {
// 获取第1列的数据id
int id = result.getInt(1);
// 获取字段是name的数据结果
String name = result.getString("name");
String password = result.getString(3);
String sex = result.getNString("sex"); System.out.println("id=" + id + "\tname=" + name + "\tpassword="
+ password + "\tsex=" + sex);
}
// 一次关闭数据库流
result.close();
statement.close();
conn.close(); } }
代码的測试效果截图:
JDBC编程理论知识(1)的更多相关文章
- Mysql——JDBC编程 理论介绍
一.JDBC简介(来自俞琰--数据库老师) Java数据库编程主要使用JDBC技术.JDBC是一种用于执行SQL语句的Java API.它由一组用Java编写的类和接口组成.JDBC为开发人员提供了一 ...
- 用VC进行COM编程所必须掌握的理论知识
一.为什么要用COM 软件工程发展到今天,从一开始的结构化编程,到面向对象编程,再到现在的COM编程,目标只有一个,就是希望软件能象积方块一样是累起来的,是组装起来的,而不是一点点编出来的.结构化编程 ...
- Winsock网络编程笔记(4)----基本的理论知识
前面的笔记记录了Winsock的入门编程,领略了Winsock编程的乐趣..但这并不能算是掌握了Winsock,加深理论知识的理解才会让后续学习更加得心应手..因此,这篇笔记将记录一些有关Winsoc ...
- JDBC理论知识
JDBC理论知识 JDBC基础 JDBC(Java Database Connectivity)是一个独立于特定数据库管理系统.通用的SQL数据库存取和操作的公共接口(一组API), 定义了用来访问数 ...
- JAVA基础知识之JDBC——编程步骤及执行SQL
JDBC编程步骤 下面以mysql数据库为例, 1.加载驱动 首先需要下载数据库的驱动jar文件,并且在eclipse包中加入到class path中去, 例如mysql的驱动文件 mysql-con ...
- JDBC编程之事务的使用教程
转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/5868750.html 关于事务的理论知识.ACID特性等等,网上太多了,在此不一一重复.本文主要着重 事务 ...
- 单独使用jdbc编程问题总结(一)
在学习Mybatis之前,我们先来回顾JDBC编程的相关知识.在此基础上深入的学习Mybatis框架.如有错误,敬请指正. (一)首先我们既然要使用jdbc,当然是要操作数据库了.创建一个名为:myb ...
- 浅谈JDBC编程
一.概述 1.为什么要用JDBC 数据库是程序不可或缺的一部分,每一个网站和服务器的建设都需要数据库.对于大多数应用程序员(此处不包含数据库开发人员)来说,我们更多的不是在DBMS中对数据库进行操纵, ...
- [转] DDD领域驱动设计(三) 之 理论知识收集汇总
最近一直在学习领域驱动设计(DDD)的理论知识,从网上搜集了一些个人认为比较有价值的东西,贴出来和大家分享一下: 我一直觉得不要盲目相信权威,比如不能一谈起领域驱动设计,就一定认为国外的那个Eric ...
随机推荐
- css容器
.s1{ background-color:pink; font-weight:bold; font-size=16px; color:black; } #id1{ background-color: ...
- Win32环境下代码注入与API钩子的实现(转)
本文详细的介绍了在Visual Studio(以下简称VS)下实现API钩子的编程方法,阅读本文需要基础:有操作系统的基本知识(进程管理,内存管理),会在VS下编写和调试Win32应用程序和动态链接库 ...
- 16aspx源码要求安装.csproj类型怎么安装
更改打开方式(不要双击打开),右键项目-打开方式选VS打开(应该会出现一个转换界面,转换下就好了).如果没有出那个界面我也没办法了
- NYOJ 21.三个水杯-初始态到目标态的最少次数-经典BFS
题目传送门:biubiubiu~ 三个水杯 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 给出三个水杯,大小不一,并且只有最大的水杯的水是装满的,其余两个为空杯子. ...
- linux文件名匹配
* 匹配文件名中的任何字符串,包括空字符串. ? 匹配文件名中的任何单个字符. [...] 匹配[ ]中所包含的任何字符. [!...] 匹配[ ]中非感叹号!之后的字符. 如: s* ...
- 第十二届北航程序设计竞赛决赛网络同步赛 B题 前前前世(数论推导 + DP)
题目链接 2016 BUAA-Final Problem B 考虑一对可行的点$(x, y)$ 根据题意,设$x = ak + 1,y = bk + 1$ 又因为$x$是$y$的祖先的祖先的祖先,所 ...
- WORDPRESS改为https部署
1.确保你已经正确开启了httpd 2.4.6的https配置,并且配置了该网站的虚拟主机,如下所示: <VirtualHost *:443> DocumentRoot "/ap ...
- poj1743(后缀数组)
poj1743 题意 给出一个数字序列(串),现在要去寻找一个满足下列条件的子串: 长度不小于 5 存在重复的子串(如果把一个子串的所有数字都加上或减去一个值,与另一子串的数字对应相同,我们称它们重复 ...
- ZOJ1027 Travelling Fee(DP+SPFA)
给一张有向无环图,边都有花费,从某点到某点走的那条路径上的那一条花费最多的边可以省掉,问从起点到终点的最少花费的多少, 往DP想的话,就可以写出这个状态dp[u][mx],表示到达u点已经省掉的花费为 ...
- 彻底解决INSTALL_FAILED_UPDATE_INCOMPATIBLE的安装错误、安装包与之前设备上的安装包签名不一致
有时候开发的问题:会遇到在公司上班的时候,公司的IDE能跑程序,把程序拷贝回家,再跑一次,就会出现以下错误: INSTALL_FAILED_UPDATE_INCOMPATIBLE 原因:就是你的安装包 ...