JDBC实现CRUD(增删改查)
- 什么是jdbc
JDBC:java database connectivity:java数据库连接,就是java连接数据库的技术
- jdbc原理
sun公司只是提供数据库的接口,不提供驱动,驱动由数据库厂商自己开发,然后java程序通过各个数据库厂商的驱动程序,连接到各个厂商的数据库。
DriverManager : 管理jdbc驱动==由java提供
Connection: 连接(通过DriverManager产生) java连接数据库的类
Statement(PreparedStatement) :增删改查 (通过Connection产生 )把sql语句发送到数据库的对象
CallableStatement : 调用数据库中的 存储过程/存储函数 (通过Connection产生 )
Result :查询数据返回的结果集 (上面的Statement等产生 )查询数据
- 实现步骤
jdbc访问数据库的具体步骤:
a.导入驱动程序jar包(需要buildpath)
b.加载具体的驱动类(Class.forName() 反射机制
/或者使用DriverManager.registerDriver()注册 注册只有mysql有)
c.与数据库建立连接,获取连接对象(DriverManager.getConnection())
d.获取发送sql语句的对象:statement
e.创建sql语句。这个语句跟数据库中的语句完全一样
f.发送sql,执行(executeUpdate()/executeQuery())
e.处理结果集 (查询)
g.关闭连接,释放资源(statement、connection);
注:现在即使不加载具体驱动类,在DriverManager.getConnection()也会注册。b步骤可以省略
不同数据库具体驱动
数据库驱动驱动jar 具体驱动类 连接字符串
Oracle ojdbc-x.jar oracle.jdbc.OracleDriver jdbc:oracle:thin:@localhost:1521:ORCL
MySQL mysql-connector-java-x.jar com.mysql.jdbc.Driver jdbc:mysql://localhost:3306/数据库实例名
SqlServer sqljdbc-x.jar com.microsoft.sqlserver.jdbc.SQLServerDriver jdbc:microsoft:sqlserver:localhost:1433;databasename=数据库实例名
1、使用JDBC连接数据库进行增删改
package com.m.JDBC;import java.sql.Connection;import java.sql.DriverManager;
import java.sql.Statement;import com.mysql.jdbc.Driver;public class mysqlTest {
public static void main(String[] args) throws Exception {
// Class.forName("com.mysql.jdbc.Driver");
// Driver d=new Driver();
// DriverManager.registerDriver(d);System.out.println("驱动完成");String url="jdbc:mysql://localhost:3306/emp";String name="root";String pwd="000000";Connection conn = DriverManager.getConnection(url, name, pwd);if(conn!=null) {
System.out.println("连接完成");}Statement statement = conn.createStatement();
// String sql="insert into department values(205,'办公')";//增加
// String sql="update department set id=206 where name='办公' ";//修改String sql="delete from department where id=205 ";//删除int i = statement.executeUpdate(sql);System.out.println("语句完成");if(i>0) {
System.out.println("操作成功");}statement.close();conn.close();}}
2、使用JDBC连接数据库进行查询
package com.m.JDBC;import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;public class mysqlTest2 {
public static void main(String[] args) throws Exception {
Class.forName("com.mysql.jdbc.Driver");String url="jdbc:mysql://localhost:3306/emp";String name="root";String pwd="000000";Connection conn = DriverManager.getConnection(url, name, pwd);if(conn!=null) {
System.out.println("连接完成");}Statement statement = conn.createStatement();String sql=" select * from department";//查询ResultSet i = statement.executeQuery(sql);while(i.next()) {
System.out.println(i.getInt(1)+" "+i.getString(2));}statement.close();conn.close();}
}
JDBC代码优化
- 使用工具类来封装JDBC
1、使用.properties配置文件
2、创建JDBCUtils类
创建JDBCUtils 连接数据库代码
预编译对象的使用
登录小功能代码
防止产出SQL注入问题
预编译对象解决SQL注入问题:
1)使用占位符?来创建SQL语句,当创建预编译对象的时候,就提前把SQL语句发送到数据库保存(缓存)
数据库获取到该SQL语句的结构,无法再修改。
2)执行查询的时候,发送的不是SQL语句,而是占位符的值!!!
查询返回数据的封装
查询数据出来之后,现在需要把这些查询出来的数据保存下来,供其他程序使用
使用JavaBean来保存数据
- 使用JavaBean来封装数据的步骤
1、创建JavaBean的类,类名跟数据库的表的名字一样(实体类)
2、创建private修饰的属性,属性的名字最好和数据库表字段名字一样
3、属性类型要和数据库表字段的类型基本一样
4、提供getter/setter方法
5、必须提供无参构造方法
具体实现代码
时间类型处理
实现代码