java编程之JDBC
JDBC的常用类和接口
1. DriverManager类
管理数据库中的所有驱动程序,其所有的方法都是静态方法,调用时无需实例化,通过类名就可以直接调用。
2. Connection接口
该接口代表与指定的数据库进行连接。通常通过getConnection()方法来获取实例。
Connection connection=DriverManager.getConnection(url,userString, psw);
3. Statement接口
该接口提供了向SQL传递语句的各种操作。通常首先通过Connection对象的createStatement()方法创建一个Statement对象,之后在进行相关操作。
Statement stmt=connection.createStatement();
executeUpdate方法和executeQuery方法都用来执行SQL语句,区别在于executeUpdate方法用来执行插入,删除,修改的操作,返回值为影响数据库记录的条数而executeQuery方法用来执行select查询语句,返回一个ResultSet对象。
4. PreparedStatement接口
PreparedStatement继承自Statement,用于执行动态的SQL语句,通过PreparedStatement实例执行的SQL语句,将被预编译并保存到PreparedStatement实例中,实现反复执行同一条SQL语句。
5. ResultSet接口
通常用于显示查询数据库的结果。
代码
/*
* mysql数据库已经设置完毕,本例需要访问的数据库为school库,
* 其下有表student(int id,varchar(20) name,varchar(10) sex,int age)
*/ package chen; import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; public class test {
public static void main(String[] args) {
try {
Class.forName("com.mysql.jdbc.Driver");//通过静态方法直接调用forName方法加载数据库驱动
String url=new String("jdbc:mysql://172.168.1.154:3306/school");//需要连接的数据库端口
String userString=new String("root");//定义登录数据库的用户名
String psw=new String("root");//定义登录数据库的密码
Connection connection=DriverManager.getConnection(url, userString, psw);//连接数据库
System.out.println("连接成功");
/*向数据库中添加数据
String sqlString=new String("insert into student (id,name,sex,age) value('201206','小兰','女','18')");//定义需要执行的SQL语句
// String sqlString="update student set age=30 where id=201215";//修改数据
// String sqlString="delete from student where id=201215";//删除数据
Statement stmt=connection.createStatement();//通过createStatement方法创建Statement对象
stmt.executeUpdate(sqlString);//传输需要执行的SQL语句
connection.close();//关闭连接
*/ /*
* 显示查询结果
Statement stmt=connection.createStatement();
String sqlString=new String("select * from student");
//select * from student where name like '%小%'查询anme中有小字的名字数据
ResultSet resultSet=stmt.executeQuery(sqlString);//获取相应SQL语句队应的ResultSet对象
int id,age;//定义临时变量来存储表的内容
String name,sex;
System.out.println("student表的内容如下");
System.out.println("id\t\t name\t sex\t age");
//next()方法用于判断是否数据表中还有数据,每次读取一行数据
while(resultSet.next()){
id=resultSet.getInt(1);//获取该行的第一列的数据,也可以通过列名来指定,即与id=resultSet.getInt("id")等价
name=resultSet.getString(2);//name=resultSet.getString("name")
sex=resultSet.getString(3);//sex=resultSet.getString("sex")
age=resultSet.getInt(4);//age=resultSet.getInt("age")
System.out.println(id+"\t"+name+"\t\t"+sex+"\t"+age);
}
*/
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} }
java编程之JDBC的更多相关文章
- java编程之:Unsafe类
Unsafe类在jdk 源码的多个类中用到,这个类的提供了一些绕开JVM的更底层功能,基于它的实现可以提高效率.但是,它是一把双刃剑:正如它的名字所预示的那样,它是 Unsafe的,它所分配的内存需要 ...
- Java编程之Map中分拣思想。
题目:给定一个字符串,求出字符串中每一个单词在字符串中出现的次数 旨意:map的分拣思想. 每一个key的包装类,存放出现的次数 /** * 作为包装类,用来存放英文单词,和该英文单词出现的次数 * ...
- java编程之POI读取excel表格的内容
07版本的excel需要另外加一个jar包.xbean.jar的jar包 读取代码模板.利用模板介绍读取excel的一些poi的api这是重点 /** * 读取excel文件 * @Title: re ...
- java编程之:生成rsa密钥
通过openssl工具生成RSA的公钥和私钥(opnssl工具可在互联网中下载到,也可以点此下载无线接口包,里面包含此工具) 打开openssl文件夹下的bin文件夹,执行openssl.exe文件: ...
- java编程之:org.apache.commons.lang3.text.StrTokenizer
第一个api测试:按特殊符号进行分词,并遍历每一个分词部分 public static void main(String[] args) { String aString="AB-CD-EF ...
- java编程之:按位与运算,等运算规则
按位与运算符(&) 参加运算的两个数据,按二进制位进行“与”运算. 运算规则:0&0=0; 0&1=0; 1&0=0; 1&1=1; 即:两位 ...
- Java编程之Date的相关操作
一:讲字符串的时间格式数据转换成时间对象 //将字符串的时间数据,转换成时间 String dateString="2007-12-12"; DateFormat date=new ...
- java网络编程之TCP通讯
java中的网络编程之TCP协议的详细介绍,以及如何使用,同时我在下面举2例说明如何搭配IO流进行操作, /* *TCP *建立连接,形成传输数据的通道: *在连接中进行大数据量传输: *通过三次握手 ...
- Java并发编程之CAS
CAS(Compare and swap)比较和替换是设计并发算法时用到的一种技术.简单来说,比较和替换是使用一个期望值和一个变量的当前值进行比较,如果当前变量的值与我们期望的值相等,就使用一个新值替 ...
随机推荐
- 【HDOJ6218】Bridge(线段树,set,网格图,连通性)
题意:给定一张2×n的网格图,一开始矩阵所有相邻点之间有一条边 有q个询问,每次给出两个相邻的点的坐标,将其中的边删除或者添加,问如此操作之后整张图的割边数量 n,q<=2*10^5, ...
- 【HDOJ5974】A Simple Math Problem(构造,解方程)
题意:给定A与B,要求构造出一组X,Y,使得X+Y=A,lcm(X,Y)=B A<=2e4,B<=1e9 思路:A的范围较小,考虑以A为突破口 枚举A的约数k,复杂度O(sqrt(A)) ...
- java 四种方式实现字符流文件的拷贝对比
将D:\\应用软件\\vm.exe 拷贝到C:\\vm.exe 四种方法耗费时间对比 4>2>3>1 package Copy; import java.io.Buffere ...
- 微信小程序 wx.navigateTo()传参及多个参数方法
var workModeAndPriceList = res.data.data.workModeAndPriceList; //var result = JSON.stringify(workMod ...
- Xamarin.Forms特殊的视图BoxView
Xamarin.Forms特殊的视图BoxView BoxView是Xamarin.Forms比较特殊的视图.该视图构建非常简单,其作用也很单一.它的作用就是构成一个特定颜色的色块.在界面设计中, ...
- 海量端口扫描工具masscan
海量端口扫描工具masscan masscan号称是互联网上最快的端口扫描工具,可以6分钟扫描整个互联网,每秒可以发送一百万个数据包.为了提高处理速度,masscan定制了TCP/IP栈,从而不影 ...
- logging模块配置共享以及使用文件配置
1.配置共享 如果每个文件都配置logging,那就太繁琐了,logging提供了父子模块共享配置的机制, 会根据Logger的名称来自动加载父模块的配置.首先定义一个 main.py 文件: imp ...
- 2012-2013 ACM-ICPC, NEERC, Central Subregional Contest
A Hanoi Tower 递归 题意: 大家都很熟悉汉诺塔的递归程序,现在给你一个组合,询问你这个组合是否会出现在汉诺塔的递归过程中. 题解: 将汉诺塔的递归程序反过来思考,考虑当前最大的那个盘,我 ...
- 【原创】关于jquery实现格式化时间
//js格式化时间,参数jsonDate可以是后台数据 function jsonDateFormat(jsonDate) { try { var date = new Date(parseInt(j ...
- 如何突破Windows环境限制打开“命令提示符”
如今,许多企业或组织都会通过使用受限的windows环境来减少系统表面的漏洞.系统加固的越好,那么也就意味着能被访问和使用到的功能就越少. 我最近遇到的情况是,一个已经加固的系统同时受到McAfee ...