利用JDBC连接MySQL并使用MySQL
driver为JDBC的驱动。
url为数据库的地址。
usrname和password分别为数据库的用户名和密码。
Connection类用来连接MySQL。
PreparedStatement类用来预编译sql语句,并可以执行。有的地方也用Statement。因为PreparedStatement继承了Statement,并且在执行多次查询更新的时候比Statement更快。PreparedStatement的第一次执行消耗是很高的,它的性能体现在重复执行。比如当我使用PreparedStatement来进行查询的时候,JDBC会发送一个网络请求来编译这个查询语句,在执行时会产生另外一个网络请求来执行。但是当我执行多次相同的查询的时候,使用PreparedStatement只会产生一个网络请求来执行语句。但如果使用Statement还会产生一个网络请求来编译语句。
ResultSet用来存储结果,一般用到select语句时用。
import java.sql.*;
class MySQL {
private static final String driver = "com.mysql.jdbc.Driver";
private static final String url = "jdbc:mysql://localhost:3306/school";
private static final String usrname = "root";
private static final String password = "";
private Connection con = null;
private PreparedStatement ps = null;
private ResultSet rs = null;
//创建student表
public MySQL() {
//如果不存在Student表则创建
String sql = "create table if not exists Student(name char(10), "
+ "sno char(10) primary key, age smallint, sex char(6), "
+ "sdept char(4))";
//加载驱动
try {
Class.forName(driver);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
try {
con = DriverManager.getConnection(url, usrname, password);//连接数据库
ps = con.prepareStatement(sql);//预编译sql语句
ps.executeUpdate();//执行sql语句更新
//必须按顺序关闭并且必须关闭
try {
if (ps != null)
ps.close();
if (con != null)
con.close();
} catch (SQLException e) {
e.printStackTrace();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
//插入多条信息
public void addInfo(String[] name, String[] sno, int[] age, String[] sex,
String[] sdept) {
String sql = "insert into student(name, sno, age, sex, sdept) "
+ "values(?, ?, ?, ?, ?);";
try {
Class.forName(driver);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
try {
con = DriverManager.getConnection(url, usrname, password);
ps = con.prepareStatement(sql);//只需要预编译一次
for (int i = 0; i < name.length; i++) {
ps.setString(1, name[i]);
ps.setString(2, sno[i]);
ps.setInt(3, age[i]);
ps.setString(4, sex[i]);
ps.setString(5, sdept[i]);
ps.executeUpdate();
}
try {
if (ps != null)
ps.close();
if (con != null)
con.close();
} catch (SQLException e) {
e.printStackTrace();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
//删除多条信息
public void deleteInfo(String[] name) {
String sql = "delete from student where name = ? ;";
try {
Class.forName(driver);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
try {
con = DriverManager.getConnection(url, usrname, password);
ps = con.prepareStatement(sql);
for (int i = 0; i < name.length; i++) {
ps.setString(1, name[i]);
ps.executeUpdate();
}
try {
if (ps != null)
ps.close();
if (con != null)
con.close();
} catch (SQLException e) {
e.printStackTrace();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
//查询多条信息
public void searchInfo(String[] name) {
String sql = "select * from student where name like ? ;";
try {
Class.forName(driver);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
try {
con = DriverManager.getConnection(url, usrname, password);
ps = con.prepareStatement(sql);
for (int i = 0; i < name.length; i++) {
ps.setString(1, name[i]);
rs = ps.executeQuery();//返回的查询结果存在结果集里面
if (rs.next()) {
do {
System.out.println("Name: " + rs.getString(1) + ", Sno: "
+ rs.getString(2) + ", age:" + rs.getString(3)
+ ", sex: " + rs.getString(4) + ", sdept: "
+ rs.getString(5));
} while (rs.next());
}
else {
System.out.println("There is no one named " + name[i] + ".");
}
}
try {
if (rs != null)
rs.close();
if (ps != null)
ps.close();
if (con != null)
con.close();
} catch (SQLException e) {
e.printStackTrace();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}
public class TestJDBC {
static String[] name = {"Mike", "Tom", "Jack", "Amy", "Allen"};
static String[] sno = {"2013210001", "2013210002", "2013210003", "2013210004", "2013210005", };
static int[] age = {21, 22, 25, 20, 24};
static String[] sex = {"female", "female", "female", "male", "male"};
static String[] sdept = {"CS", "EE", "SE", "CS", "SE"};
public static void main(String[] args) {
//创建Student表
System.out.println("Creating table student!");
MySQL sq = new MySQL();
//添加学生信息
System.out.println("\nTesting add data!");
sq.addInfo(name, sno, age, sex, sdept);
//删除Tom和Allen的信息
System.out.println("\nTesting delete data!");
String[] del = {"Tom", "Allen"};
sq.deleteInfo(del);
//查询Tom,Amy和Mike的信息。
System.out.println("\nTesting search data!");
String[] sear = {"Tom", "Amy", "Mike"};
sq.searchInfo(sear);
System.out.println("\nSuccess!");
}
}
上述代码运行结果如下
Creating table student!
Testing add data!
Testing delete data!
Testing search data!
There is no one named Tom.//因为上一部已经将Tom删除
Name: Amy, Sno: 2013210004, age:20, sex: male, sdept: CS
Name: Mike, Sno: 2013210001, age:21, sex: female, sdept: CS
Success!
利用JDBC连接MySQL并使用MySQL的更多相关文章
- 2、Java应用中常见的JDBC连接字符串(SQLite、MySQL、Oracle、Sybase、SQLServer、DB2)
2.Java应用中常见的JDBC连接字符串 Java应用中连接数据库是不可或缺的,于是便整理一些可能用到的JDBC的jar包及其相匹配的URL,以备日后查阅. 1)SQLite Class.forNa ...
- 利用jdbc连接oracle数据库
JDBC是Sun公司制定的一个可以用Java语言连接数据库的技术. 一.JDBC基础知识 JDBC(Java Data Base Connectivity,java 数据库连接)是一种用于执行SQL语 ...
- 利用JDBC连接Eclipse和mySQL5.1.26数据库
初学JDBC,看了看书,自己动手的时候还是有很多地方有问题,最终终于解决了实现了数据库的连接.现将整个步骤描述如下: 环境:mySQL5.1.26(win 32bit), Eclipse JavaEE ...
- 利用jdbc连接池(利用jdni)
简介 前段时间用jdbc连接池,在这里记录下 1.利用jdni配置数据源 在Web项目的META-INF文件夹中新建context.xml文件,内容为: <?xml version=" ...
- 利用JDBC连接Oracle数据库(转)
http://blog.csdn.net/wahaha1_/article/details/8512438 JDBC是Sun公司制定的一个可以用Java语言连接数据库的技术. 一.JDBC基础知识 J ...
- Android学习笔记————利用JDBC连接服务器数据库
/******************************************************************************************** * auth ...
- 怎样利用JDBC连接并操作Oracle数据库
之前学习.NET的时候.以前利用ODBC进行连接数据库,而在Java中通常採用JDBC连接数据库,这里以oracle数据库为例简单的总结一下利用JDBC怎样连接并操作数据库. 1.连接 public ...
- jdbc的配置及jdbc连接常用数据库(mysql、sqlserver、Oracle)
1.连接SQL Server数据库 import java.sql.*; publicclassMain{publicstaticvoid main(String[] args){String dri ...
- JDBC连接MySQL数据库及演示样例
JDBC是Sun公司制定的一个能够用Java语言连接数据库的技术. 一.JDBC基础知识 JDBC(Java Data Base Connectivity,java数据库连接)是一种用 ...
随机推荐
- 在filter中使用spring的service bean
http://blog.csdn.net/godha/article/details/13025099
- I/O流——其他流
其他流 一.ObjectInputStream/ObjectOutputStream ① ObjectInputStream和ObjectOutputStream分别与FileInputStream和 ...
- Struts2理解--动态方法和method属性及通配符_默认Action
众所周知,默认条件下,在浏览器输入indexAction!execute.action,便会执行indexAction类里的execute方法,这样虽然方便,但可能带来安全隐患,通过url可以执行Ac ...
- oracle 表被锁定 杀死进程
/*查出被锁biao*/ select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,dba_obje ...
- java获取classpath
public class PathTest { public static void main(String[] args) { //获取根路径三种方式 System.out.println(Path ...
- 在Spring MVC项目中,注解方式使用 .properties 文件及 UTF-8编码问题
xml配置 <!-- 配置文件 --> <bean id="configProperties" class="org.springframework.b ...
- 约瑟夫环问题(c++)
#include <iostream> struct node{ int payload; node* next; node(int payload){this->payload = ...
- JVM内存模型和性能优化
JVM内存模型优点 内置基于内存的并发模型: 多线程机制 同步锁Synchronization 大量线程安全型库包支持 基于内存的并发机制,粒度灵活控制,灵活度高于数据库锁. 多核并行计算模 ...
- libxml2 移植 arm9
准备工作: 1.libxml2软件版本:libxml2-2.6.32.tar.gz 2.交叉编译工具链:arm-none-linux-guneabi 软件安装: 1.设置环境变量: export PA ...
- C#实现自动单击
最新玩了一下上学时候玩的游戏,但游戏里面变化太多了,进去后等级就很高,要不停地点击鼠标加技能. 所以利用工作中常用的C#调用 API不停地点击鼠标. 如图: 为方便在基础上修改,我把整个解决方案放到百 ...