在mysql中建立表格,表名称和列的定义都使用键盘输入,用户数据也要通过键盘输入。

此程序来源于《java 开发实战经典》第17章

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.Statement;
//下面是数据输入类
class InputData {
private BufferedReader buf = null;


public InputData() {
this.buf = new BufferedReader(new InputStreamReader(System.in));
}


public String getString(String info) {//输入字符串
String temp = null;
System.out.print(info);
try {
temp = buf.readLine();
} catch (IOException ee) {
ee.printStackTrace();
}
return temp;
}


public String getTableString(String info, String err) {//输入列的名称及类型
String temp = null;
boolean flag = false;
while (flag == false) {
System.out.println("类型有:INT,VARCHAR(M),FLOAT,描述有:AUTO_INCREMENT,NOT NULL,DEFAULT'男',PRIMARY KEY已经有不用.");
temp = new InputData().getString(info);
String s[] = temp.split(" ");
if (s.length > 1) {
flag = true;
} else {
System.out.println(err);
}
}
return temp;
}
//下面方法判断输入的字符串是否符合:(姓名 性别 年龄 语文分数 数学分数 英语分数)的格式 
public boolean infoString(String infor) {
int n = 0;
String ss[]=infor.split(" ");//如果输入的信息空格太少会导致对象数组个数少于6,不存在的对象会导致程序异常。
String s[] = new String[6];
for(int i=0;i<6;i++) {
if(i>ss.length-1) {//如果s序号大于ss最后一个序号。
s[i]="";
}else {
s[i]=ss[i];
}
}
if ((s[1].equals("男")==false) && (s[1].equals("女")==false)) {
n++;
if (n == 1) {
System.out.print("输入的性别");


}
}


if (s[2].matches("^\\d+$")) {
if (Integer.parseInt(s[2]) < 0 || Integer.parseInt(s[2]) > 200) {
n++;
if (n == 1) {
System.out.print("输入的年龄");
}
System.out.print(",年龄");
}
} else {
n++;
if (n == 1) {
System.out.print("输入的年龄");
}
System.out.print(",年龄");
}
if (s[3].matches("^\\d{1,3}.?\\d?$")) {
if (Float.parseFloat(s[3]) < 0 || Float.parseFloat(s[3]) > 100) {
n++;
if (n == 1) {
System.out.print("输入的语文分数");
}
System.out.print(",语文分数");
}
} else {
n++;
if (n == 1) {
System.out.print("输入的语文分数");
}
System.out.print(",语文分数");
}
if (s[4].matches("^\\d{1,3}.?\\d?$")) {
if (Float.parseFloat(s[4]) < 0 || Float.parseFloat(s[4]) > 100) {
n++;
if (n == 1) {
System.out.print("输入的数学分数");
}
System.out.print(",数学分数");
}
} else {
n++;
if (n == 1) {
System.out.print("输入的语文分数");
}
System.out.print(",语文分数");
}


if (s[5].matches("^\\d{1,3}.?\\d?$")) {
if (Float.parseFloat(s[5]) < 0 || Float.parseFloat(s[5]) > 100) {
n++;
if (n == 1) {
System.out.print("输入的语文分数");
}
System.out.print(",英语分数");
}
} else {
n++;
if (n == 1) {
System.out.print("输入的语文分数");
}
System.out.print(",英语分数");
}
if (n > 0) {
System.out.print("不正确");
return false;
} else {
return true;
}
}
}


public class AndrewK17_161 {
public static final String DBDRIVER = "com.mysql.jdbc.Driver";
public static final String DBURL = "jdbc:mysql://localhost:3306/andrew?useUnicode=true&characterEncoding=utf-8&useSSL=false";
public static final String DBUSER = "root";
public static final String DBPASS = "3269";
    public static String sql2=null;
public static void main(String[] args)throws Exception {
Connection conn = null;
Class.forName(DBDRIVER);
conn = DriverManager.getConnection(DBURL, DBUSER, DBPASS);
settable(conn);//创建表格
setInformation(conn,sql2);//插入信息
conn.close();
}
//创建数据库表格方法。
public static void settable(Connection conn1)throws Exception {
Statement stmt = null;
String name = new InputData().getString("请输入数据库名称:");
String idcolumn = new InputData().getTableString("请输入id列字段名称,类型及描述(中间以空格隔开):", "输入错误,请重新输入!");
String namecolumn = new InputData().getTableString("请输入姓名列字段名称,类型及描述(中间以空格隔开):", "输入错误,请重新输入!");
String sexcolumn = new InputData().getTableString("请输入性别列字段名称,类型及描述(中间以空格隔开):", "输入错误,请重新输入!");
String agecolumn = new InputData().getTableString("请输入年龄列字段名称,类型及描述(中间以空格隔开):", "输入错误,请重新输入!");
String chicolumn = new InputData().getTableString("请输入中文列字段名称,类型及描述(中间以空格隔开):", "输入错误,请重新输入!");
String mathcolumn = new InputData().getTableString("请输入数学列字段名称,类型及描述(中间以空格隔开):", "输入错误,请重新输入!");
String engcolumn = new InputData().getTableString("请输入英语列字段名称,类型及描述(中间以空格隔开):", "输入错误,请重新输入!");
String sql0 = "DROP TABLE IF EXISTS " + name;// sql0和sql这两条命令为什么不能整在一起?
String sql = "create table " + name + "(" + idcolumn + " primary key," + namecolumn + "," + sexcolumn + ","
+ agecolumn + "," + chicolumn + "," + mathcolumn + "," + engcolumn + ")";

       String namecolumns[]=namecolumn.split(" ");
       String sexcolumns[]=sexcolumn.split(" ");
       String agecolumns[]=agecolumn.split(" ");
       String chicolumns[]=chicolumn.split(" ");
       String mathcolumns[]=mathcolumn.split(" ");
       String engcolumns[]=engcolumn.split(" ");
       sql2 = "INSERT INTO " + name + "(" + namecolumns[0] + "," + sexcolumns[0] + "," + agecolumns[0] + "," + chicolumns[0]
+ "," + mathcolumns[0] + "," + engcolumns[0] + ")VALUES(?,?,?,?,?,?)";
       System.out.println(sql2);
stmt = conn1.createStatement();
stmt.executeUpdate(sql0);
stmt.executeUpdate(sql);
stmt.close();
}
//插入信息方法。
public static void setInformation(Connection conn1, String sql)throws Exception {// 主类中的方法要static;
PreparedStatement pstmt = null;
String ss = sql;
boolean flag = false;
while (flag == false) {
String stin = new InputData()
.getString("学生信息的格式为:姓名 性别 年龄 语文成绩 数学成绩 英语成绩(按顺序输出,中间以空格隔开),如果输入0,结束信息输入并退出。\r\n请输入学生信息:");
String s[] = stin.split(" ");
if (stin.equals("0")) {
break;
}


if (new InputData().infoString(stin) == true) {
pstmt = conn1.prepareStatement(ss);// 实例化PreparedStatement.
pstmt.setString(1, s[0]);//设置姓名
pstmt.setString(2, s[1]);//设置性别
pstmt.setInt(3, Integer.parseInt(s[2]));//设置年龄
pstmt.setFloat(4, Float.parseFloat(s[3]));//设置语文分数
pstmt.setFloat(5, Float.parseFloat(s[4]));//设置数学分数
pstmt.setFloat(6, Float.parseFloat(s[5]));//设置英语分数
pstmt.executeUpdate();


} else {
System.out.println("请重新输入!");
}


}


}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值