写在前面

通过自己编写的Java代码程序,去模仿实现MySql客服端的简单功能,最终以控制台操作,很像在Dos窗口通过命令操作MySql数据库。

关键问题

在编写过程中遇到的一些小问题和一些值得留心注意的点:

  • 增删改查结果是否成功的获得
  • 查询结果 不定集列数的获得
1  //获取结果集的列数
2 78 ResultSetMetaData rsmd = rs.getMetaData();
3 79 int i = rsmd.getColumnCount();
  • 完整代码
 1 import java.sql.*;
2 import java.util.*;
3
4 public class YouSqlClient {
5
6 private static String name = "";
7 private static String passwor = "";
8 static Connection con;
9 static Statement statement = null;
10 static ResultSet rs;
11 static Scanner input = new Scanner(System.in);
12
13 public static void main(String[] args) {
14
15 System.out.println("userName:");
16 name = input.nextLine();
17 System.out.println("password:");
18 passwor = input.nextLine();
19
20 try {
21
22 String sql = "";
23
24 Class.forName("com.mysql.jdbc.Driver").newInstance();//初始化数据库驱动
25 //指定链接数据库的信息
26 con = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/mydbone?useUnicode=true&characterEncoding=UTF-8",name,passwor);
27 statement = con.createStatement();
28 System.out.println("login succeded!");//上面的语句成功执行,提示登陆成功
29
30 boolean isExit = true;
31
32 while(isExit) {//通过循环不断接收命令
33
34 System.out.println("Please enter the commend>");
35
36 //登陆后的操作
37 sql = input.nextLine();//测试:show databases;
38
39 try {
40 if( sql.indexOf( "use" ) == 0 ) {//换数据库
41 statement.executeQuery( sql );
42 System.out.println("Database changed!");
43 }
44 else if ( ( sql.indexOf( "show" ) == 0 || sql.indexOf( "select" ) == 0) && statement.execute(sql) ) { //查表
45 selectOperate();
46 }
47 else if ( statement.execute(sql) ) {//不是对表内数据的增删该查,不是数据库的切换,不是show table或者 DB
48 //建立新表 + 删除表 + 等等其他操作
49 }
50 else if (sql.equals("exit")) {
51 isExit = false;
52 System.out.println("exit succeded!");
53 }
54 else {
55 System.out.println( "query succedes!" );
56 }
57 } catch (SQLException e) {
58 e.printStackTrace();
59 }
60 }
61 } catch (InstantiationException e) {
62 e.printStackTrace();
63 } catch (IllegalAccessException e) {
64 e.printStackTrace();
65 } catch (ClassNotFoundException e) {
66 e.printStackTrace();
67 } catch (SQLException e) {
68 e.printStackTrace();
69 }
70 }
71
72 //查询
73 static void selectOperate() throws SQLException {
74
75 rs = statement.getResultSet();
76
77 //获取结果集的列数
78 ResultSetMetaData rsmd = rs.getMetaData();
79 int i = rsmd.getColumnCount();
80
81 //列名
82 for( int j = 1; j <= i; j++ ) {
83
84 System.out.print(rsmd.getColumnName(j) + "\t");
85 }
86 System.out.println("\n----------------------------------------------");
87
88 while( rs.next() ) { // 依次获得查询结果,每次执行nest,换一行
89
90 for( int j = 1; j <= i; j++ ) {
91
92 System.out.print(rs.getString(j) + "\t");
93 }
94 System.out.println();
95 }
96 }
97
98 }

编程模仿MySql客服端的更多相关文章

  1. python socket 客服端服务端编程

    客服端编程 import socket try: s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) except socket.error a ...

  2. Python网络编程UDP服务器与客服端简单例子

    [转载] https://blog.csdn.net/hu330459076/article/details/7868028 UDP服务器代码: #!/usr/bin/env python # -*- ...

  3. 浏览器与服务器间的交互(客服端 <---> 服务器)

    浏览器与服务器间的交互(客服端 <---> 服务器) 请求--->处理--->响应 对类HttpContext 内部成员的使用 例如 :Request .Response .  ...

  4. android客服端+eps8266+单片机+路由器之远程控制系统

    用android客服端+eps8266+单片机+路由器做了一个远程控制的系统,因为自己是在实验室里,所以把实验室的门,灯做成了远程控制的. 控制距离有多远------只能说很远很远,只要你手机能上网的 ...

  5. python服务器端、客户端的模型,客服端发送请求,服务端进行响应(web.py)

    服务器端.客户端的模型,客服端发送的请求,服务端的响应 相当于启动了一个web server install web.py 接口框架用到的包 http://webpy.org/tutorial3.zh ...

  6. cas 服务端、客服端详细配置

    一.准备 1.下载官方源码 CAS-Server下载地址:https://www.apereo.org/projects/cas/download-cas CAS-Client下载地址:http:// ...

  7. 客服端JavaScript线程模型

    JavaScript语言核心并不包含任何线程机制,并且客服端JavaScript传统上没有定义任何线程机制.HTML5定义了一种作为后台线程的“WebWorker",但是客服端JavaScr ...

  8. 使用Mosquitto实现MQTT客服端C语言

      上一篇文章已经将mosquitto移植到了arm平台上,现在将使用mosquitto完成mqtt客服端的demo,了解过mqtt协议的小伙伴都知道,mqtt主要分为代理服务器.发布者.订阅者三部分 ...

  9. TCP服务器端和客服端(一)

    就是一个客服端(Socket)和服务器(ServerSocket)端的链接间.我的理解是一个服务端可以链接多个客服端. 在客服端有输入流outPutStream. 用于发送数据 在服务器端有输出流.i ...

随机推荐

  1. 25道经典Java算法题

    题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?   //这是一个菲波拉契数列问题 [Java] 纯 ...

  2. Focal Loss(RetinaNet)笔记 一种减小类别不平衡影响的方法

    Paper: https://arxiv.org/abs/1708.02002 还参考了:https://www.jianshu.com/p/8e501a159b28 其中p是预测属于某类的概率.

  3. vue 根据身份证计算出出生日期和判断性别

    //获取生日和性别     getBirth(idCard) {              var birthday = "";       if(idCard != null & ...

  4. 前端路由原理之 hash 模式和 history 模式

    什么是路由? 个人理解路由就是浏览器 URL 和页面内容的一种映射关系. 比如你看到我这篇博客,博客的链接是一个 URL,而 URL 对应的就是我这篇博客的网页内容,这二者之间的映射关系就是路由. 其 ...

  5. Spring Cloud Eureka 实践(二)

    接上一篇的内容,Eureka服务已经启动成功后,可以尝试开发服务的提供者与消费者,并注册到Eureka来实现服务的发现与调用. 首先,在父工程中继续创建服务提供者的Module,最新的目录结构如下图所 ...

  6. Git:为Git Bash.exe设置默认起始目录的两种方式(start in、~/.bashrc)

    在协作开发的过程中,我们经常要进行一些项目的上传拉取操作. 在无数次不厌其烦的打开关闭 Git Bash 后,我实在忍受不了作为一个程序员还要每次都要进行如下的小白操作了 cd /d/my-proje ...

  7. redis存取数据String

    一.连接不同数据库和存取String类型值 1.连接数据库 2.set和get多个 3.取值并赋值 取值返回的是赋值改变之前的值: 4.递增和递减 5.字符串尾部加值 6.商品编号自增应用

  8. sass和js的联动(共享变量)

    一般做共享变量用于主题功能 假设我们在xxx.scss中声明了一个 theme:blue,我们在 js 中该怎么获取这个变量呢?我们可以通过import variables from '@/style ...

  9. java短信群发项目:

    编写一个项目, 1. 以下手机号码段,添加到Map集合当中 2. 从控制台输入要发送信息的短信号码,如果要发送多个,请用英文逗号隔开,输入短信内容 3. 编写一个短信发送类,号码发送前,先判断号码是否 ...

  10. python 小鸡飞行小游戏

    python 小鸡飞行小游戏 用空格键控制小鸡飞行 代码 import pygame.freetype import sys import random pygame.init() screen = ...