JDBC的使用——Statement
JDBC是Java最基本的数据库操作途径,虽然现在有了更高端的Hibernate和JPA,但是其实它们的底层还是用的这些最基本的JDBC。而且,如果开发一个小型的应用程序,使用Hibernate不免有些大材小用,使用起来也相当笨重。使用JDBC的大概过程为:1,加载JDBC驱动程序 2,创建数据库连接 3,执行SQL语句(Statement,PreparedStatement和CallableStatement) 4,获得查询结果 5,关闭连接。这篇日志先只使用Statement演示数据库的插入,删除,修改,查询。
MyeClipse里新建一个Java Project。首先别忘了把sqljdbc4.jar加入classpath。可以直接去改那个.classpath文件,也可以在MyEclipse下这样操作:工具栏Project->Properties->Java Build Path->Libraries然后点击Add External JARs按钮,找到sqljdbc4.jar的路径就OK了。
写的代码如下:
import .......;
public class Test1 {
//连接本地数据库的两种写法
// private static final String URL="jdbc:sqlserver://localhost:1433;DatabaseName=TestDB";
// private static final String URL="jdbc:sqlserver://127.0.0.1:1433;DatabaseName=TestDB";
private static final String URL="jdbc:sqlserver://222.26.168.72:1433;DatabaseName=TestDB";
//连接异地数据库,这里用的是寝室另一台电脑的IP
private static final String USERNAME="sa";
private static final String PASSWORD="1234";
static{
try {
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");//加载JDBC驱动程序
} catch (ClassNotFoundException e) {
System.out.println("发生如下异常:");
e.printStackTrace();
}
}
public static void main(String[] args) {
try {
Connection conn=DriverManager.getConnection(URL, USERNAME,PASSWORD);//建立数据库连接
Statement statement=conn.createStatement();
//插入记录*********************************************************************
String sql="insert into cchild values('Roney2','Tomsy2','1998-02-06',12)";
String sql2="insert into cchild values('Kaka','yyu','1998-02-06',12)";
//statement.executeUpdate(sql);
statement.execute(sql);//可以不使用executQuery或者executUpdate方法了
statement.execute(sql2);
//修改记录*********************************************************************
String sql3="update cchild set age=13 where birthday='1998-02-06'";
statement.execute(sql3);
//删除记录*********************************************************************
String sql4="delete from cchild where cusername='Wu'";
statement.execute(sql4);
//查询记录*********************************************************************
String sql5="select * from cchild";
statement.execute(sql5);
ResultSet rs=statement.getResultSet();//注意这里有错
//也可以用ResultSet rs= statement.executeQuery(sql5);代替上面两条语句
ResultSetMetaData rsmd=rs.getMetaData();//这里能够得到 返回数据表的详细信息 ,列标号也是从1开始
System.out.println(rsmd.getColumnName(1)+" "+rsmd.getColumnName(2)+" "+
rsmd.getColumnName(3)+" "+rsmd.getColumnName(4));//得到各列的列名
while (rs.next()) {
String cusername=rs.getString(1);//从1开始的
String childname=rs.getString(2);
String birthdaty=rs.getString(3);
int age=rs.getInt(4);
System.out.println(cusername+" "+childname+" "+birthdaty+" "+age);
}
statement.close();//关闭statement
conn.close();//关闭数据库连接
System.out.println("success***********");
} catch (SQLException e) {
System.out.println("产生异常");
e.printStackTrace();
}
}
}
JDBC的使用——Statement的更多相关文章
- JDBC中的Statement和PreparedStatement的区别
JDBC中的Statement和PreparedStatement的区别
- MySQL异常:Caused by: com.mysql.jdbc.exceptions.MySQLTimeoutException: Statement cancelled due to timeout or client request
Caused by: com.mysql.jdbc.exceptions.MySQLTimeoutException: Statement cancelled due to timeout or cl ...
- jdbc中的Statement对象和Preparedstatement对象的区别,以及通过jdbc操作调用存储过程
一. java.sql.* 和 javax.sql.*的包的类结构 |- Driver接口: 表示java驱动程序接口.所有的具体的数据库厂商要来实现此接口. |- connect(url, p ...
- JDBC batch批处理Statement executeBatch 具体解释
JDBC提供了数据库batch处理的能力,在数据大批量操作(新增.删除等)的情况下能够大幅度提升系统的性能.我曾经接触的一个项目,在没有採用batch处理时,删除5万条数据大概要半个小时左右,后来对系 ...
- JDBC batch批量Statement executeBatch 详细解释
JDBC提供了数据库batch处理的能力,在数据大批量操作(新增.删除等)的情况下能够大幅度提升系统的性能.我曾经接触的一个项目,在没有採用batch处理时,删除5万条数据大概要半个小时左右,后来对系 ...
- JDBC中的Statement和PreparedStatement的差别
以Oracle为例吧 Statement为一条Sql语句生成运行计划, 假设要运行两条sql语句 select colume from table where colume=1; select col ...
- JDBC的使用-----Statement
JDBC的查询步骤1.加载数据库驱动类 1)在工程下新建lib文件夹,将 ojdbc6.jar(jar包在:E:\oracle\product\11.2.0\dbhome_1\jdbc\lib)拷贝至 ...
- Java -- JDBC 学习--通过Statement进行数据库更新操作
通过 JDBC 向指定的数据表中插入一条记录. 1. Statement: 用于执行 SQL 语句的对象 1). 通过 Connection 的 createStatement() 方法来获取 2). ...
- [转] JDBC中的Statement和PreparedStatement的区别
以Oracle为例吧 Statement为一条Sql语句生成执行计划,如果要执行两条sql语句select colume from table where colume=1;select colume ...
随机推荐
- UDP数据接收服务器
简介 这是我在做一个要用UDP方式进行数据传输时,自己写的一个多线程的UDP数据接收服务器, 它能将接收到的UDP数据包存成文件,并提供数据包接收时间监测: 还支持键盘命令响应,以将数据写到新的文件, ...
- !!!!OpenWrt系列教程汇总
OpenWrt FAQ https://dev.openwrt.org.cn/wiki/faqs OpenWrt编译教程 完全新手教程:openwrt编译全过程(sse) 直接编译出带中文的openw ...
- 【POJ1581】A Contesting Decision(简单模拟)
没有什么弯路,直接模拟即可.水题. #include <iostream> #include <cstring> #include <cstdlib> #inclu ...
- HTTPS证书生成原理和部署细节
看看下面,部分电信用户访问京东首页的时候,会看到右下角有一个浮动广告: 小白用户以为是京东有意放置的,细心的用户会发现,这个 iframe 一层嵌一层的恶心广告很明显是电信/中间人通过 DNS 劫持注 ...
- c++之 变量
变量的基本操作 变量就是一个可以变化的量,变量由变量类型.变量名.初始值(可选)组成,例如: int abc = 10; 变量类型:int 变量名:abc 初始值:10 // 该值为可选项,在创建变量 ...
- New Year Table(几何)
New Year Table Time Limit:2000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u Sub ...
- hdu 4923 Room and Moor (单调栈+思维)
题意: 给一个0和1组成的序列a,要构造一个相同长度的序列b.b要满足非严格单调,且 值为0到1的实数.最后使得 sum((ai-bi)^2)最小. 算法: 首先a序列開始的连续0和末尾的连续1是能 ...
- Android应用程序线程消息循环模型分析
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6905587 我们知道,Android应用程序是 ...
- Android窗口管理服务WindowManagerService对窗口的组织方式分析
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/8498908 我们知道,在Android系统中, ...
- IoC容器Autofac之实例引入(一)
先不必尝试理解IOC,先来看段代码. 一.一个没有使用IoC的例子 public class MPGMovieLister { public Movie[] GetMPG() { var finder ...