JDBC的基础接口及其用法
JDBC基础
所谓JDBC即是:Java DataBase Connectivity,java与数据库的连接。是一些用来执行SQL语句的Java API。
我们进行JDBC的编程,主要常用的几个概念:Connection 、 Statement 、PreparedStatement 、 ResultSet。
一、Connection对象
Connection对象,代表与数据源进行的唯一会话。如果是客户端/服务器数据库系统,该对象可以等价于到服务器的实际网络连接。简单点介绍,在java编程中即是java程序与数据库之间的一个数据通道,所有对数据库中数据的操作,均需要通过这个通道进行,因此,该对象也是进行与数据库对接的首要创建对象,该对象提供了很多方法,用来实现与程序与数据库的数据交互,常见的有
××××.getConnection(url, user, password) //建立数据库的连接通道(会话)
.Closed()//关闭连接 .isClosed() //通道是否关闭
createStatement() //创建statement对象 prepareStatement(sql); //创建prepareStatement对象,sql为未填装语句
二、Statement对象
Statement对象,是 Java 执行数据库操作的一个重要接口,用于在已经建立数据库连接的基础上,向数据库发送要执行的SQL语句。Statement对象,用于执行不带参数的简单SQL语句。主要作用即是向数据库发送一些简单的SQL语句,使得java通过statement即可对数据库中的数据进行增删改查,该对象一般通过Connection对象的createStatement()方法来创建。它常用的方法有:
executeQuery() // 执行SQL语句,并返回一个ResultSet的实例
三、PreparedStatement对象
PreparedStatement继承自Statement,也是一个向数据库发送SQL语句的接口,相比于Statement,它具有更高频率的使用,向它传入的SQL语句可以使用占位符,是预编译的,SQL 语句被预编译并存储在 PreparedStatement 对象中。然后可以使用此对象多次高效地执行该语句。所谓占位符的SQL语句即是一种输入了键但是对应的值用 ?来代替的SQL语句,例如: select password from grils where id = ? ,这里的 ? 未确定的值,可以根基后续的set***方法来填装完成,使他成为完整的SQL语句
该对象常用的方法有:
set××××(int,string)//填装SQL语句中占位符的参数
executeQuery() //执行带填装完成的SQl语句,返回一个ResultSet实例
四、ResultSet对象
ResultSet,数据库结果集的数据表,通过执行查询数据库的语句生成,以statement / preparedstatement的execteQuery方法返回,该对象返回了数据库执行SQL语句后的结果集,通过其特有的方法,可以在java中提取出这些数据集。常用方法:
next();//用于遍历循环结果集
getString()//返回String类型的值
getInt()//返回Int类型的值
等等
具体实现JDBC连接代码
public class JdbcUtil {
private static String url="jdbc:mysql://127.0.0.1:3306/user";
private static String user="root";
private static String password="root";
private static Connection con = null;
static{
try {
Class.forName("com.mysql.jdbc.Driver");//映射加载数据库驱动
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
con = DriverManager.getConnection(url, user, password);//传入账号密码,建立连接
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public static Connection getConnection()
{
try {
con = (con==null||con.isClosed())?DriverManager.getConnection(url, user, password):con;
//判断连接是否建立
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return con;//返回通道
}
}
public class Opearte {
public boolean getuser(String username,String password) throws SQLException
{
String sql = "select password from user where id=?";
Connection con = JdbcUtil.getConnection();
PreparedStatement stat = con.prepareStatement(sql);//预处理sql语句生成可执行数据
ResultSet rs = null;
stat.setString(1, username);
rs = stat.executeQuery();
while(rs.next())
{
if( password.equals(rs.getString("password")))
{
return true;
}
}
return false;
}
}
JDBC的基础接口及其用法的更多相关文章
- Java 基础 接口和多态
接口 接口的概念 接口是功能的集合,同样可看做是一种数据类型,是比抽象类更为抽象的”类”. 接口只描述所应该具备的方法,并没有具体实现,具体的实现由接口的实现类(相当于接口的子类)来完成.这样将功能的 ...
- Java JDBC的基础知识(一)
一.为什么引入JDBC 在学习JDBC之前,抛开它的概念,我先按照我的理解解释一下,为什么要引入JDBC.在我看来,引入JDBC跟我之前学过的引入JVM(Java虚拟机)有些相似之处.当然,关于JVM ...
- MMORPG大型游戏设计与开发(服务器 AI 基础接口)
一个模块都往往需要统一的接口支持,特别是对于非常大型的模块,基础结构的统一性非常重要,它往往决定了其扩展对象的通用性.昨天说了AI的基本概述以及组成,作为与场景模块中核心一样重要的地位,基础部分的设计 ...
- jdbc执行Statement接口的步骤
jdbc执行Statement接口的步骤如下: 1)驱动注册程序: Class.forName(com.mysql.jdbc.Driver); 2)获取连接对象: Connection conn = ...
- .net微信公众号开发——基础接口
作者:王先荣 本文讲述微信公众号开发中基础接口的使用,包括以下内容: (1)获取许可令牌(AccessToken): (2)获取微信服务器地址: (3)上传.下载多媒体文件: ...
- EasyUI中Base(基础)的基本用法
EasyUI中Base(基础)的用法 一.Base(基础) 1.parser 解析器 2.easyloader 简单加载 3.draggable 拖动 4.droppable 放置 5.resizab ...
- php获取微信基础接口凭证Access_token
php获取微信基础接口凭证Access_token的具体代码,供大家参考,具体内容如下 access_token是公众号的全局唯一票据,公众号调用各接口时都需使用access_token.开发者需要进 ...
- scrapy之基础概念与用法
scrapy之基础概念与用法 框架 所谓的框架就是一个项目的半成品.也可以说成是一个已经被集成了各种功能(高性能异步下载.队列.分布式.解析.持久化等)的具有很强通用性的项目模板. 安装 Linux: ...
- face_recognition 基础接口
face_recognition 基础接口 face_recognition使用世界上最简单的人脸识别库,在Python或命令行中识别和操作人脸. 使用dlib最先进的人脸识别技术构建而成,并具有深度 ...
随机推荐
- ELK批量删除索引
一.存在问题 用了一段时间elk发现如果索引长时间不删除,elk会越来越慢,重启elasticsearch服务器节点之前同步时间也会很长 二.解决方法(定期删除索引) 1.在elasticsearch ...
- CSS快速入门-鼠标悬浮(hover伪类)
一.概述 hover伪类:在鼠标移到元素上时向此元素添加特殊的样式.比较普通的就是一个url,当你鼠标放上去后,会变颜色. 在现实的应用场景也非常之多.最常见的是网站的悬浮导航,当鼠标放到导航条上时, ...
- 深入理解JavaScript是如何实现继承的
深入理解JavaScript是如何实现继承的-----------http://www.jb51.net/article/44384.htm
- 用CSS3做3D动画的那些事
年会做了个3D变换的抽奖系统,在这里分享下通过CSS3制作3D效果的心得.抽奖系统虽然够炫酷,可惜抽的时候出了点bug,好几百人啊我的小心脏啊.虽然这个锅后面甩给会场的老爷电脑了(手动白眼). 首先介 ...
- 安装vs2017后,RDLC 报表定义具有无法升级的无效目标命名空间
原先的RDLC报表定义用的命名空间是2008,用vs2017报表设计器重新保存后,会自动升级成2016,导致无法使用. 不想升级控件,太麻烦,所以就手动修改RDLC文件吧. 1.修改http://sc ...
- Python 的AES加密与解密-需要安装的模块
踩雷1: #先导入所需要的包 pip3 install Crypto #再安装pycrtpto pin3 install pycrypto from Crypto.Cipher import AES ...
- Frida----frida tools的使用
翻译自官方网站:https://www.frida.re/docs/home/ 如果有理解不对的地方,请大家指出 frida Cll frida -U 包名 调试连接到电脑上设备中的应用 frida ...
- LintCode——尾部的零
尾部的零:设计一个算法,计算出n阶乘中尾部零的个数 样例:11! = 39916800.因此应该返回2 分析:假如你把1 × 2 ×3× 4 ×……×N中每一个因数分解质因数,例如 1 × 2 × 3 ...
- <数据结构系列1>封装自己的数组——手写动态泛型数组(简化版ArrayList)
哈哈,距离上一次写博客已经快过去半个月了,这这这,好像有点慢啊,话不多说,开始我们的手写动态泛型数组 首先是我们自己写一个自己的动态数组类,代码如下所示: public class Array< ...
- bootstrap switch样式修改与多列等间距布局
先以一张图开启今天的随笔 今天实习遇到了switch按钮,小姐姐说用插件bootstrap switch来写,我第一次用这个插件,首先在引入方面就遇到了很多坑,先来总结一下bootstrap swit ...