一、JDBC的简介
- jdbc的概述:
jdbc:java database connectivity 通过java代码去操作数据库 jdbc也是一套规范 jdbc中大部分都是接口,具体的实现是个大数据库厂商 就是jdbc接口实现的jar包。

 
- jdbc规范有哪些
 
- java.sql.DriverManager类:负责驱动的注册 和 jdbc操作的入口
 
- java.sql.Connection接口:负责连接数据库
 
- java.sql.Statement接口:负责操作数据库
 
- java.sql.ResultSet接口:负责封装查询的结果数据
 
- java.sql.PreparedStatement:负责操作数据库 对sql语句进行预编译
 
- 快速入门
     准备工作: 
- 数据库中有可操作的数据
 
- 准备数据库的驱动jar包
 
二、编码阶段:
- 操作数据库的一般流程
 
- 注册驱动
 
- 链接数据库
 
- 执行SQL语句操作数据库
 
- 遍历结果集
 
- 关闭资源
//(1) 注册驱动 
DriverManager.registerDriver(newDriver()); 
//(2) 连接数据库 
Connection conn=DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/android","root","didi848484"); 
//(3) 执行sql语句操作数据库 
//1.创建一个 Statement 对象来将 SQL 语句发送到数据库。 
Statement stem=conn.createStatement(); 
//2.执行SQL语句 
ResultSet rs=stem.executeQuery("select * from user"); 
//(4) 遍历结果集 
while(rs.next()) 
{ 
System.out.print("id:"+rs.getInt("id")); 
System.out.print(",username:"+rs.getString("username")); 
System.out.print(",password:"+rs.getString("password")); 
//..... 
System.out.println(); 
} 
//(5) 关闭资源 
		rs.close(); 
		stem.close(); 
		conn.close(); 
 
 
- 数据库连接流程详解
 
- 注册驱动
一般有2种方式:
1.第一种方式,使用DriverManager提供的方法来注册
格式:DriverManager.registerDriver(new Driver())//这里的new Driver()一定要导入对应数据库JAR包中的类
例子:DriverManager.registerDriver(new Driver()); //这种方式一半不使用,原因是跟踪源码发现,源码内驱动重复注册,影响效率。

2.第二种方式:使用反射来注册
格式:Class.forName("驱动的全包名");
例子:Class.forName("com.mysql.jdbc.Driver");
Class.forName("com.mysql.jdbc.Driver"); 
 
开发中一般使用反射的方式来注册驱动。好处有两点,一:驱动只注册一次,提高了效率。二:可以将驱动的全包名提取成配置文件 解耦合 方便后期维护
 
- 连接数据库
格式:Connection conn = DriverManager.getConnection(url,name,password);
url:数据库的地址
      格式:主协议:子协议://主机:端口/数据库名称
      示例:jdbc:mysql://localhost:3306/jdbc
      注意:如果主机是本机(localhost)端口也是默认的3306则可以简写为:jdbc:mysql:///jdbc
name:用户名
password:密码 
- 创建Statement来执行sql语句
 
- 创建Statement对象
格式:Statement stmt = conn.createStatement(); 
- 执行sql语句
使用Statement 对象下的2个方法来执行SQL语句
a.int executeUpdate(String sql) : 返回值int 是影响的行数//主要用来执行:增、删、改语句或者不返回任何内容的SQL语句(如 SQL DDL 语句)
b.ResultSet    executeQuery(String sql) :执行查询语句 返回结果ResultSet//主要用于接收select 语句查询的结果 
- ResultSet结果集
ResultSet内部封装的是查询返回的数据:ResultSet就是对查询的结果的封装就可以看成一张表 其内部维护着一个游标(指针)起初游标指向在第一条数据的上面,当我们执行next()方法时,游标会向下窥探一下是否存在下一条数据,如果有next方法会返回true,并且游标向下移动一行,如果没有下一条数据返回false,当游标指向某一行时,可以通过getXXX()方法取得这一行中的某一个字段下的数据。
如何取ResultSet中的数据
1.首先通过next()方法窥探结果集中是否有下一行数据,如果有返回true且结果集指针移动到下一行,否则返回false
2.当next()方法返回为true时,可以通过ResultSet对象的方法取出数据,如:getInt()     getString()     getDate()    getObject()  括号内参数:字段名称 (查询出的字段名称)
//创建ResultSet对象来接收查询结果 
ResultSet rs=stem.executeQuery("select * from user"); 
//通过next()和各类get方法取出数据	 
while(rs.next()) 
{ 
System.out.print("id:"+rs.getInt("id")); 
System.out.print(",username:"+rs.getString("username")); 
System.out.print(",password:"+rs.getString("password")); 
//..... 
System.out.println(); 
} 
 
 
- 关闭资源
原则:与数据库有关系的资源全部关闭 从小到大关闭
RresultSet---->Statement------->Connection 
 
JDBC(数据库的连接和使用)
原文:http://www.cnblogs.com/didixyy/p/6a3f7a2251b4fcf4b8d75823ca081eed.html