JDBC 程序实例小练习
JDBC 程序实例问题
编程实现如下功能:在数据库中建立一个表,表名为student,其结构为学号、姓名、性别、年龄、英语、JavaSE程序设计、初级日语、总分,在表中输入多条记录。
- 学生的总分信息,通过修改总分 = 英语 + JavaSE程序设计+ 初级日语
- 查询所有学生的信息,并显示出来。
- 查询所有不及格成绩的学生信息。
- 插入一条记录。
- 修改性别为男的所有学生的年龄 = 年龄 + 1.
- 删除(4)题目中插入的记录
- 将表中记录按照总分降序输出。
代码实现
package www.yjl;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Scanner;
public class Test1 {
public static void main(String[] args) {
try {
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/hair?useUnicode=true&characterEncoding=utf8","root","123456");
//(1)计算总分
String updateSql = "update student set 总分=英语+JavaSE程序设计+初级日语";
PreparedStatement pst = conn.prepareStatement(updateSql);
int zf = pst.executeUpdate();
if (zf > 0)
{
System.out.println("总分计算成功!");
}
System.out.println("-------------------------");
//查询所有学生的信息,并显示出来
String showAll = "select * from student";
PreparedStatement pst1 = conn.prepareStatement(showAll);
ResultSet rs = pst1.executeQuery();
while (rs.next())
{
for (int i = 1;i <= 9;i++)
{
System.out.print(rs.getString(i)+" ");
}
System.out.println();
}
System.out.println("-------------------------");
//查询不及格成绩的学生信息
String showFild = "select * from student where 英语<60 or JavaSE程序设计<60 or 初级日语 <60";
PreparedStatement pst2 = conn.prepareStatement(showFild);
ResultSet rsshouFild = pst2.executeQuery();
while (rsshouFild.next())
{
for (int i = 1;i <= 9;i++)
{
System.out.print(rsshouFild.getString(i)+" ");
}
System.out.println();
}
System.out.println("-------------------------");
//插入一条数据
System.out.println("Now you will alowed to import a line:");
String insertLine = "insert into student(Id,学号,姓名,性别) values(?,?,?,?)";
//String updateSql1="update student set 学号=?,姓名=? where 性别=?";
PreparedStatement pstInsert=conn.prepareStatement(insertLine);
Scanner sc = new Scanner(System.in);
System.out.println("请输入学生ID:");
String id=sc.next();
System.out.println("请输入学生学号:");
String number=sc.next();
System.out.println("请输入学生姓名:");
String name=sc.next();
System.out.println("请输入学生性别:");
String sex=sc.next();
pstInsert.setString(1, id);
pstInsert.setString(2, number);
pstInsert.setString(3, name);
pstInsert.setString(4, sex);
int y = pstInsert.executeUpdate();
if(y>0)
{
System.out.println("恭喜你插入了一条新的数据!");
}
System.out.println("-------------------------");
//这是你点击输入的时候,光标没有自动跳转到你要放你输入内容的地方,他在的地方可能已经有了内容,所以你输入内容就输入不进去,
//解决办法就是把光标点到你要输入内容的地方,这是eclipse本身的缺陷,目前应该还没有解决办法。
//一直存在输入不进去的bug,这是找到的答案....次奥!!!!搞我半个小时,我还以为代码有问题.....
//修改性别为男的所有学生的年龄=年龄+1
String updateBoyOld = "update student set 年龄=年龄+1 where 性别 ='男'";
PreparedStatement pstupdateBoyOld = conn.prepareStatement(updateBoyOld);
int boyplus = pstupdateBoyOld.executeUpdate();
if (boyplus > 0)
{
System.out.println("年龄加 1 成功!");
}
System.out.println("-------------------------");
//将表中记录按照总分降序输出
String updateSoreDesc = "select * from student order by 总分 desc";
PreparedStatement pstSoreDesc = conn.prepareStatement(updateSoreDesc);
ResultSet rsSoreDesc = pstSoreDesc.executeQuery();
while (rsSoreDesc.next())
{
for (int i = 1;i <= 9;i++)
{
System.out.print(rsSoreDesc.getString(i)+" ");
}
System.out.println();
}
System.out.println("-------------------------");
//删除数据
String deleteSql="delete from student where 学号=?";
PreparedStatement pstDelete=conn.prepareStatement(deleteSql);
pstDelete.setString(1,"1005");
int e = pstDelete.executeUpdate();
if (e>0)
{
System.out.println("删除成功!");
}
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
小结
这个程序是昨晚搞出来的,也算是一个没有界面的小程序了,用的是一个测试类,代码冗长...enmmm...
一百多行代码,最终写完,其中,发现自己还是有好多问题,自己还有好多东西要学习啊。。。现在还是蒟蒻啊....本来是想着昨晚接着贴出来的,有点事情给耽搁了....
JDBC 程序实例小练习的更多相关文章
- JDBC程序实例
实例 ( Statement ): public class JDBC { public static void main(String[] args) throws Exception { Conn ...
- 微信小程序实例源码大全
微信小程序实例源码大全下载 微信小应用示例代码(phodal/weapp-quick)源码链接:https://github.com/phodal/weapp-quick 微信小应用地图定位demo( ...
- 微信小程序实例教程(一)
序言 开始开发应用号之前,先看看官方公布的「小程序」教程吧!(以下内容来自微信官方公布的「小程序」开发指南) 本文档将带你一步步创建完成一个微信小程序,并可以在手机上体验该小程序的实际效果.这个小程序 ...
- 微信小程序实例-摇一摇抽奖
概述 前面我们讲了如何开始微信小程序搭建和一些组件的介绍.微信小组件和微信小程序入门 微信小程序目录 为了更好的理解小程序和小程序开发,我们首先来看一下项目的目录. 首先看下根目录下的app.json ...
- 开发一个微信小程序实例教程
一.注册小程序账号 1.进入微信公众平台(https://mp.weixin.qq.com/),注册小程序账号,根据提示填写对应的信息即可.2.注册成功后进入首页,在 小程序发布流程->小程序开 ...
- 微信小程序实例源码大全下载
小程序QQ交流群:131894955 小程序开发直播腾讯课堂: https://edu.csdn.net/course/detail/6743 微信小程序实例源码大全下载 微信小应用示例代码(p ...
- 微信小程序实例代码
http://blog.csdn.net/zuoliangzhu/article/details/53862576#t1 项目结构 └─ empty-folder/ ················· ...
- 微信小程序实例源码大全2
wx-gesture-lock 微信小程序的手势密码 WXCustomSwitch 微信小程序自定义 Switch 组件模板 WeixinAppBdNovel 微信小程序demo:百度小说搜索 sh ...
- Android开发5:应用程序窗口小部件App Widgets的实现
前言 本次主要是实现一个Android应用,实现静态广播.动态广播两种改变 widget内容的方法,即在上篇博文中实验的基础上进行修改,所以此次实验的重点是AppWidget小部件的实现啦~ 首先,我 ...
随机推荐
- 常用接口简析3---IList和List的解析
常用接口的解析(链接) 1.IEnumerable深入解析 2.IEnumerable.IEnumerator接口解析 3.IComparable.IComparable接口解析 学习第一步,先上菜: ...
- 开源API测试工具 Hitchhiker v0.5更新 - 完善细节
Hitchhiker 是一款开源的支持多人协作的 Restful Api 测试工具,支持Schedule, 数据对比,压力测试,支持上传脚本定制请求,可以轻松部署到本地,和你的team成员一起管理Ap ...
- Eclipse创建一个JAVA WEB项目
继上一篇博客,Eclipse的Tomcat已经配置好了,现在我们开始创建web项目. 1.打开Eclipse,选择菜单栏的file>New>Dynamic Web Project 弹出窗口 ...
- 微软云计算 Massive Data 处理语言Scope 1
Massive Data处理一直是云计算中很重要的一个环节.目前像Google,Yahoo在相关方面都有自己专有的技术.例如Google的基于MapReduce的Sawzall语言.和Yahoo基于H ...
- Less的嵌套规则
Less的嵌套规则 在使用标准CSS时,要为多层嵌套的元素定义样式,要么使用后代选择器从外到内的嵌套定义,要么给这个元素加上类名或 id 来定义.这样的写法虽然很好理解,但维护起来很不方便,因为无法清 ...
- SaltStack 架构自动部署 03
架构图 模块化部署 系统模块:系统优化,内核参数,网络参数 功能模块:如:nginx,tomcat, 业务模块: 1.在salt-master端修改配置文件 [root@01 salt]# vim / ...
- Python入门 - 面向对象
python很好的支持面向对象编程,本节主讲类的定义,类的构造方法,类的继承与方法重写,类的多继承. 一.类的定义 class Myclass() : def prt(self, str) : pri ...
- PHP入门怎么选?大学生适合学习吗?
大学毕业,面对竞争激烈的社会,理想总是很丰满,现实却很残酷.在硕士.博士都随处可见的今天,本科和大专文凭就显得苍白无力,在面试官问你"有没有工作经验"的时候,你是不是只想起实习期间 ...
- CCF-201503-1-图象旋转
问题描述 试题编号: 201503-1 试题名称: 图像旋转 时间限制: 5.0s 内存限制: 256.0MB 问题描述: 问题描述 旋转是图像处理的基本操作,在这个问题中,你需要将一个图像逆时针旋转 ...
- UWP 保存Image的图片到本地文件
上一篇说显示一张图片到Image控件,比较简单. 那个假设我Image控件有图片了,想保存到本地,这个就要花心思了,不过也不复杂的... var rtb = new RenderTargetBitma ...