java-数据库操作(JDBC)
前言:JDBC用到的API和常用方法
DriverMannager类
加载驱动并创建与数据库的连接,通常使用Class类的静态方法
forName()
来实现加载驱动,使用getConnection(String url,String user,String pwd)
方法实现连接,返回如下Connection对象Connection接口
使用
createStatement()
返回一个用于向数据库发送语句的Statement对象,prepareStatement(String sql)
返回一个用于向数据库发送参数化的SQL语句的PreparedStatement对象Statement接口
用于执行静态SQL语句,并返回一个结果对象
boolean execute(String sql)//用于执行各种SQL语句,返回布尔值,true代表有查询结果,可用getResultSet()获得查询结果
int executeUpdate(String sql)//用于执行insert、update、delete语句,返回数据库中受影响的记录条数
ResultSet executeQuery(String sql)//执行select语句,返回ResultSet对象
PreparedStatement接口
是Statement的子接口,扩展了带有参数SQL语句的执行操作,使用占位符"?"代替参数,使用setXXX()方法赋值
int executeUpdate()//执行SQL语句,限制语句为无返回内容的sql或DML语句
ResultSet executeQuery()//执行SQL查询 返回ResultSet对象
void setInt(int index,int x)//将指定的对应表头的参数设置为x
void setFloat(int index,float x)
void setString(int index,String x)
void setDate(int index, Date x)//注意:Date类型必须为java.sql.Date,非java.util.Date
ResultSet接口
用于保存查询后的结果集,封装在一个逻辑表格中,接口内部有指向表格数据行的游标(指针),调用
next()
方法作为循环条件迭代结果集String getString(int columnindex)//根据索引获取指定字段的String的值
String getString(String columnname)//根据字段名称获取指定字段的String的值
int getInt(int columnindex)//根据索引获取指定字段的int的值
int getInt(String columnname)//根据字段名称获取指定字段的int的值
Date getDate(int columnindex)//根据索引获取字段的Date值
Date getDate(String columnname)//根据字段名称获取字段的Date值
boolean next()//游标下移一行
boolean absolute(int row)//游标移动到指定行
步骤概述:
1.加载数据库驱动
数据库驱动zip包下载:https://dev.mysql.com/downloads/connector/j/
选择Platform Independent,完成后在项目结构中导入文件夹里的Jar包
Class.forName("com.mysql.jdbc.Driver");//Mysql驱动
//IDEA亲测提示上面语句已经弃用,可改为com.mysql.cj.jdbc.Driver""
Class.forName("oracle.jdbc.driver.OracleDriver");//Oracle驱动
2.通过DriverManager获取数据库连接
Connect conn=DriverManager.getConnection(String url,String user,String pwd);
url格式:jdbc:mysql://localhost:3306/database-name
3.通过Connection对象获取Statement对象
Statement stmt=conn.creatStatement();
或stmt=conn.prepareStatement(String sql);
4.使用Statement执行SQL语句
ResultSet rs=stmt.executeQuery(sql);
5.操作得到的结果集
rs.getXXX();
6.关闭连接,释放资源
在try...catch..后的finally{}中统一关闭资源
实例
public class sql {
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
ResultSet rs = null;
try {
//1.加载数据库驱动
Class.forName("com.mysql.cj.jdbc.Driver");
String url = "jdbc:mysql://114.xx.xxx.62:3306/company";
String user = "root";
String pwd = "xxxxxx";
//2.通过DriverManager获取数据库连接
conn = DriverManager.getConnection(url, user, pwd);
//3.通过Connection获取statement对象
stmt = conn.createStatement();
//4.执行SQL语句
rs = stmt.executeQuery("select * from demo1");
//5.操作结果集
while (rs.next()) {
String name = rs.getString("企业名称");
String lat = rs.getString("经纬度");
String flag1 = rs.getString("flag1");
System.out.println(name+" | "+lat+" | "+flag1);
}
}
} catch (ClassNotFoundException e) {
e.printStackTrace();
}finally {
//6.关闭连接,释放资源
if(rs!=null){rs.close();}
if(stmt!=null){stmt.close();}
if(conn!=null){conn.close();}
}
}
}
}
运行结果
最新文章
- shell脚本(管理守护进程)
- Java Hour 66 Spring 相关
- 第九篇:在SOUI中使用多语言翻译
- spring aop 中获取 request
- [转]error: 'retainCount' is unavailable: not available in automatic reference counting mode
- eclipse web项目实际工程路径对应
- Java凝视Override、Deprecated、SuppressWarnings具体解释
- RHEL 7特性说明(六):集群
- Android Gradle配置
- 分布式搜索ElasticSearch构建集群与简单搜索实例应用
- C#中的DataSet添加DataTable问题
- Intel 移位指令的陷阱(转)
- 微服务---Eureka注册中心(服务治理)
- 手把手教你解析Resources.arsc
- 不让Editplus保存时java文件时生成.bak文件
- 【伪装位置神器】神行者AnyLocation 1.3.0001可用于微信,陌陌
- CentOS下mysql安装
- AMD、CMD、UMD 模块的写法
- 2018.07.10NOIP模拟 Knapsack(单调队列优化dp)
- Smarty中section的使用
热门文章
- zabbix5.0监控安全配置全过程
- 《手把手教你》系列技巧篇(五十四)-java+ selenium自动化测试-上传文件-中篇(详细教程)
- centos6.5-svn搭建文档
- 关于java的Excel导入导出之easypoi
- js获取设备公网ip + 服务器根据公网ip 获取IP信息
- spring cloud --- Zuul --- 心得
- 第10组 Alpha冲刺 (3/6)(组长)
- Java对象内存模型
- 详解__int128
- Xamarin/Unity3d无法访问Azure服务器或者微软API