JDBC 练习
建立两个表,一个水果表一个用户表。
1.要求输入账号和密码,登陆成功显示欢迎界面,失败提示错误
2.显示选择界面,输入不同的数字,显示不同的内容,,并实现不同的功能,并返回界面
import java.awt.image.Raster;
import java.sql.*;
import java.util.*; public class ZuoYe {
public static String zh; public static void main(String [] args) throws Exception {
Scanner sc=new Scanner(System.in);
System.out.println("请输入账号");
zh=sc.nextLine();
System.out.println("请输入密码");
String mm=sc.nextLine(); Class.forName("com.mysql.jdbc.Driver"); String jdbc="jdbc:mysql://127.0.0.1:3306/mydb";
Connection conn=DriverManager.getConnection(jdbc, "root", "");
String sql="select * from login where UserName=? and Password=? ";
PreparedStatement state= conn.prepareStatement(sql);
state.setString(1, zh);
state.setString(2, mm);
ResultSet re=state.executeQuery(); if(re.next()){
System.out.println("登陆成功!"+re.getString(2)+",欢迎你!");
jm();
}
else{
System.out.println("账号或密码输入错误");
} conn.close();
} public static void jm() throws Exception{
Scanner sc=new Scanner(System.in);
System.out.println("************请选择服务项目***************");
System.out.println("1.显示所有商品");
System.out.println("2.添加商品");
System.out.println("3.购买商品");
System.out.println("4.退出");
String xz=sc.nextLine();
if(xz.equals("1")){
xianshi();
jm();
}
else if(xz.equals("2")){
tianjia();
xianshi();
jm();
}
else if(xz.equals("3")){
goumai();
xianshi();
}
else if(xz.equals("4")){
return;
}
else{
System.out.println("输入有误");
}
} public static void xianshi() throws Exception{
Class.forName("com.mysql.jdbc.Driver");
String jdbc="jdbc:mysql://127.0.0.1:3306/mydb";
Connection conn=DriverManager.getConnection(jdbc, "root", "");
String sql="select * from fruit";
PreparedStatement state=conn.prepareStatement(sql);
ResultSet re=state.executeQuery();
System.out.println("*********************************************");
System.out.println("商品编号"+"\t"+"商品名称"+"\t"+"单价"+"\t"+"原产地"+"\t"+"剩余商品数量");
while(re.next()){
System.out.println(re.getString(1)+"\t"+re.getString(2)+"\t"+re.getDouble(3)+"\t"+re.getString(4)+"\t"+re.getInt(5));
}
System.out.println("*********************************************");
conn.close();
} public static void tianjia() throws Exception{
Scanner sc=new Scanner(System.in);
System.out.println("请输入商品属性:商品编号-商品名称-单价-原产地-添加数量,属性之间用-隔开");
String sp=sc.nextLine();
String [] str=sp.split("-");
double qz=Double.parseDouble(str[2]) ;
int sl=Integer.parseInt(str[4]);
Class.forName("com.mysql.jdbc.Driver");
String jdbc="jdbc:mysql://127.0.0.1:3306/mydb?characterEncoding=GBK";
Connection conn=DriverManager.getConnection(jdbc, "root", "");
String sql="insert into fruit values(?,?,?,?,?,NULL)";
PreparedStatement state=conn.prepareStatement(sql);
state.setString(1, str[0]);
state.setString(2, str[1]);
state.setDouble(3, qz);
state.setString(4, str[3]);
state.setInt(5, sl);
state.executeUpdate();
System.out.println("添加成功!!!"); conn.close();
} public static void goumai() throws Exception{
Scanner sc=new Scanner(System.in);
System.out.println("请输入购买的水果种类或代号");
String mz=sc.nextLine();
System.out.println("请输入购买数量");
int sl=Integer.parseInt(sc.nextLine()); Class.forName("com.mysql.jdbc.Driver");
String jdbc="jdbc:mysql://127.0.0.1:3306/mydb?characterEncoding=GBK";
Connection conn=DriverManager.getConnection(jdbc,"root","");
conn.setAutoCommit(false); //查询苹果单价
String sql2="select * from fruit where Name=? or Ids=?";
PreparedStatement state=conn.prepareStatement(sql2);
state.setString(1, mz);
state.setString(2, mz);
ResultSet re=state.executeQuery();
re.next();
double zj=re.getDouble(3)*sl;//总价格 //修改商品数量
String sl_sql="update fruit set Numbers=? where Name=? or Ids=?";
PreparedStatement state_sl=conn.prepareStatement(sl_sql);
state_sl.setInt(1, (re.getInt(5)-sl));
state_sl.setString(2, mz);
state_sl.setString(3, mz);
state_sl.executeUpdate(); //修改用户剩余钱数
String sy="update login set Account=Account-? where UserName=?";
PreparedStatement dstate=conn.prepareStatement(sy);
dstate.setDouble(1, zj);
dstate.setString(2, zh);
dstate.executeUpdate(); //最后查询剩余钱数
String zhye="select * from login where UserName=?";
PreparedStatement state_ye=conn.prepareStatement(zhye);
state_ye.setString(1, zh);
ResultSet re1 =state_ye.executeQuery();
re1.next();
System.out.println("购买成功!!!您当前账户余额为"+re1.getDouble(4)+"元");
conn.commit();
conn.close();
} }



JDBC 练习的更多相关文章
- Java数据库连接技术——JDBC
大家好,今天我们学习了Java如何连接数据库.之前学过.net语言的数据库操作,感觉就是一通百通,大同小异. JDBC是Java数据库连接技术的简称,提供连接各种常用数据库的能力. JDBC API ...
- 玩转spring boot——结合AngularJs和JDBC
参考官方例子:http://spring.io/guides/gs/relational-data-access/ 一.项目准备 在建立mysql数据库后新建表“t_order” ; -- ----- ...
- [原创]java使用JDBC向MySQL数据库批次插入10W条数据测试效率
使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(100000),如何提高效率呢?在JDBC编程接口中Statement 有两个方法特别值得注意:通过使用addBatch( ...
- JDBC MySQL 多表关联查询查询
public static void main(String[] args) throws Exception{ Class.forName("com.mysql.jdbc.Driver&q ...
- JDBC增加删除修改
一.配置程序--让我们程序能找到数据库的驱动jar包 1.把.jar文件复制到项目中去,整合的时候方便. 2.在eclipse项目右击"构建路径"--"配置构建路径&qu ...
- JDBC简介
jdbc连接数据库的四个对象 DriverManager 驱动类 DriverManager.registerDriver(new com.mysql.jdbc.Driver());不建议使用 ...
- JDBC Tutorials: Commit or Rollback transaction in finally block
http://skeletoncoder.blogspot.com/2006/10/jdbc-tutorials-commit-or-rollback.html JDBC Tutorials: Com ...
- FineReport如何用JDBC连接阿里云ADS数据库
在使用FineReport连接阿里云的ADS(AnalyticDB)数据库,很多时候在测试连接时就失败了.此时,该如何连接ADS数据库呢? 我们只需要手动将连接ads数据库需要使用到的jar放置到%F ...
- JDBC基础
今天看了看JDBC(Java DataBase Connectivity)总结一下 关于JDBC 加载JDBC驱动 建立数据库连接 创建一个Statement或者PreparedStatement 获 ...
- Spring学习记录(十四)---JDBC基本操作
先看一些定义: 在Spring JDBC模块中,所有的类可以被分到四个单独的包:1.core即核心包,它包含了JDBC的核心功能.此包内有很多重要的类,包括:JdbcTemplate类.SimpleJ ...
随机推荐
- Nested Loops join时显示no join predicate原因分析以及解决办法
本文出处:http://www.cnblogs.com/wy123/p/6238844.html 最近遇到一个存储过程在某些特殊的情况下,效率极其低效, 至于底下到什么程度我现在都没有一个确切的数据, ...
- 模仿Linux内核kfifo实现的循环缓存
想实现个循环缓冲区(Circular Buffer),搜了些资料多数是基于循环队列的实现方式.使用一个变量存放缓冲区中的数据长度或者空出来一个空间来判断缓冲区是否满了.偶然间看到分析Linux内核的循 ...
- 【干货分享】流程DEMO-借款申请
流程名: 借款申请 业务描述: 当员工个人在工作中需要进行借款时,通过此项流程提交借款申请,审批通过后,财务部进行款项支付. 流程相关文件: 流程包.xml WebService业务服务.xm ...
- 星浩资本快速发展引擎:IT就是生产力
星浩资本成立于2010年,是一家涵盖私募基金.开发管理.商业与现代服务业三大业务范围的综合性管理公司,专注于投资中国首创.高成长性.高回报率的创新型城市综合体. 年轻的星浩资本在商业投资上有其独到的商 ...
- Microsoft Visual Studio 2017 for Mac Preview 下载+安装+案例Demo
目录: 0. 前言 1. 在线安装器 2. 安装VS 3. HelloWorld 4. ASP.NET MVC 5. 软件下载 6. 结尾 0. 前言: 工作原因,上下班背着我的雷神,一个月瘦了10斤 ...
- Xamarin.Android活动的生命周期
一.前言 用过Android手机的人一定会发现一种现象,当你把一个应用置于后台后,一段时间之后在打开就会发现应用重新打开了,但是之前的相关的数据却没有丢失.可以看出app的“生命”是掌握在系统手上的, ...
- JS中给正则表达式加变量
前不久同事询问我js里面怎么给正则中添加变量的问题,遂写篇博客记录下. 一.字面量 其实当我们定义一个字符串,一个数组,一个对象等等的时候,我们习惯用字面量来定义,例如: var s = &quo ...
- 快速构建App界面的框架(●'◡'●) -----SalutJs
前言 卤煮在公司之初接触到的是一个微信APP应用.前端技术采用的是Backbone+zepto等小型JS类库.在项目开发之初,这类中小型的项目采用这两种库可以满足基本的需求.然而,随着迭代的更新和业务 ...
- Entity Framework 6 Recipes 2nd Edition(9-5)译->删除一个断开的实体
9-5. 删除一个断开的实体 问题 我们要把一个把WCF上取回的对象做上删除的标志. 解决方案 假设我们有如Figure 9-5所示实体的支付与票据的模型. Figure 9-5. 一个支付与票据的模 ...
- [翻译]AKKA笔记 - CHILD ACTORS与ACTORPATH -6
原文:http://rerun.me/2014/10/21/akka-notes-child-actors-and-path/ Actor是完全的继承结构.你创建的任何Actor肯定都是一个其他Act ...