Java Web简明教程–Java篇[8]–连接MySQL

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Java Web简明教程–Java篇[8]–连接MySQL

回顾一下之前,我们已安装了MySQL5.5,同时设定了密码Pass1234。所以打开【开始】-【程序】-【MySQL】-【MySQL5.5 Command Line Client】,也就是MySQL命令行客户端,可以对MySQL进行一些最基本的操作,如下图:

image.png


分别执行了show databases——展示所有数据库、use mysql——使用mysql数据库、show tables——展示mysql数据库中的表,三个命令,命令行界面给人一种高端神秘的感觉,但是猫哥觉得很不直观,所以给大家介绍一个非常好用的MySQL数据库管理工具——Navicat。


请自行百度下载安装Navicat for MySQL(猫哥使用的是10.0.11版本,各版本差距不大),安装过程是傻瓜式的下一步安装,此处不为表述。


打开Navicat,点击【连接】按钮连接到我们本机安装的数据库,如下图:

image.png


简单的解释下,【连接名】随个人喜好随便起就行,主机名或IP地址此处可以填写【localhost】或者【127.0.0.1】,这两个都是代表的本机,端口3306是我们安装MySQL时候设定的,用户名root是超级管理员的,密码是安装MySQL时候设定的Pass1234,输入完成后点击【连接测试】,提示连接成功后点击【确定】就OK了。


好的,我们建立一个【java】数据库,用来学习和测试,如下图,字符集建议选择utf-8,因为我们要使用中文嘛:

image.png


然后我们新建一张表student_info(学生信息表),如下图:

image.png

需要注意几点:

1,id是唯一标识,name表示姓名,因为可能有重名的,所以我们用id唯一区分学生,注意id是主键(不能重复,右边那个钥匙一样的标志表示设置为主键),然后id是自动递增的,也就是从1开始自动加1,我们往这个表添加数据的时候,不用管id,它会自动增长。

2,猫哥建议列名不要直接起id、name,而是用student_id、student_name,因为表多了之后,字段和表明相关,容易帮我们区分,当然这是一个习惯问题。

3,类型int 表示数字型,varchar表示字符串类型,长度20表示最大长度。

建立完毕后,可以采用【ER图表】方式查看表结构,如图:

image.png

是不是很赞很直观。


OK,我们随意在这张表里输入几条数据:

image.png


数据库工具有了,此时就要用Java语言来跟数据库交互了。首先我们需要一个驱动,这个驱动的作用就是沟通Java和数据库(就像打印机驱动沟通打印机和我们的计算机一个道理)。从**[驱动下载]**(http://downloads.mysql.com/archives/c-j/)下载该驱动,下载5.1.39版本即可。在Java目录下建立一个jar目录,将下载后解压的mysql-connector-java-5.1.39-bin.jar放在其中(以后下载的jar文件都放在里面,集中管理,体现了猫哥高端大气的管理思维…,实际上jar文件有多种放置方法,猫哥这是最懒的方法…)。


还记得我们那个神奇的WebSiteFirst项目吗,没关系,这次演示还是使用它,当然也可以另行建立一个Web Project,作为一个怀旧的人,猫哥依然用它。


右键点击这个项目,依次点击【Build Path】、【Configure Build Path…】、标签选择【Libraries】,按钮点击【Add External JARs…】,然后选中我们的mysql-connector-java-5.1.39-bin.jar后,点击OK。此时项目结构如图所示:


可见我们的项目已经成功的引入该jar文件。


不容易啊,搞了半天还没写一句Java代码,终于开始了。先新建一个类就叫TestMysql。首先准备一些最基本的参数:


public class TestMysql {//用来测试使用MySQL数据库的第一个类
  public static void main(String[] args) {
  //基本参数
        String driver = "com.mysql.jdbc.Driver";//MySQL数据库的驱动程序名
        String url = "jdbc:mysql://localhost:3306/java?useUnicode=true&characterEncoding=utf-8";//数据库连接字符串
        String user = "root";//用户名
        String password = "root";//密码
  }
}


OK,接下来就是使用驱动程序连接MySQL了,代码如下:


import java.sql.*;
public class TestMysql {//用来测试使用MySQL数据库的第一个类
  public static void main(String[] args) {
  //基本参数
        String driver = "com.mysql.jdbc.Driver";//MySQL数据库的驱动程序名
        String url = "jdbc:mysql://localhost:3306/java?useUnicode=true&characterEncoding=utf-8";//数据库连接字符串
        String user = "root";//用户名
        String password = "Pass1234";//密码
        try{   
          Connection con=DriverManager.getConnection(url,user,password);   
          System.out.println("数据库连接成功");   
        }
        catch(SQLException ex){   
            System.out.println("数据库连接失败,原因"+ex.getMessage());   
        }   
  }
}

运行后,提示数据库连接成功,不过好像没什么意思,那可以把密码改成Pass12345,然后再运行提示:


数据库连接失败,原因Access denied for user 'root'@'localhost' (using password: YES)

1

这下,看来真的跟MySQL握手成功了。


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
12天前
|
消息中间件 Java 数据库
自研Java框架 Sunrays-Framework使用教程「博客之星」
### Sunrays-Framework:助力高效开发的Java微服务框架 **Sunrays-Framework** 是一款基于 Spring Boot 构建的高效微服务开发框架,深度融合了 Spring Cloud 生态中的核心技术组件。它旨在简化数据访问、缓存管理、消息队列、文件存储等常见开发任务,帮助开发者快速构建高质量的企业级应用。 #### 核心功能 - **MyBatis-Plus**:简化数据访问层开发,提供强大的 CRUD 操作和分页功能。 - **Redis**:实现高性能缓存和分布式锁,提升系统响应速度。 - **RabbitMQ**:可靠的消息队列支持,适用于异步
自研Java框架 Sunrays-Framework使用教程「博客之星」
|
14天前
|
Java 数据库连接 数据处理
探究Java异常处理【保姆级教程】
Java 异常处理是确保程序稳健运行的关键机制。它通过捕获和处理运行时错误,避免程序崩溃。Java 的异常体系以 `Throwable` 为基础,分为 `Error` 和 `Exception`。前者表示严重错误,后者可细分为受检和非受检异常。常见的异常处理方式包括 `try-catch-finally`、`throws` 和 `throw` 关键字。此外,还可以自定义异常类以满足特定需求。最佳实践包括捕获具体异常、合理使用 `finally` 块和谨慎抛出异常。掌握这些技巧能显著提升程序的健壮性和可靠性。
34 4
|
13天前
|
存储 移动开发 算法
【潜意识Java】Java基础教程:从零开始的学习之旅
本文介绍了 Java 编程语言的基础知识,涵盖从简介、程序结构到面向对象编程的核心概念。首先,Java 是一种高级、跨平台的面向对象语言,支持“一次编写,到处运行”。接着,文章详细讲解了 Java 程序的基本结构,包括包声明、导入语句、类声明和 main 方法。随后,深入探讨了基础语法,如数据类型、变量、控制结构、方法和数组。此外,还介绍了面向对象编程的关键概念,例如类与对象、继承和多态。最后,针对常见的编程错误提供了调试技巧,并总结了学习 Java 的重要性和方法。适合初学者逐步掌握 Java 编程。
39 1
|
26天前
|
自然语言处理 Java 关系型数据库
Java mysql根据很长的富文本如何自动获取简介
通过使用Jsoup解析富文本并提取纯文本,然后根据需要生成简介,可以有效地处理和展示长文本内容。该方法简单高效,适用于各种应用场景。希望本文对您在Java中处理富文本并生成简介的需求提供实用的指导和帮助。
54 14
|
2月前
|
移动开发 前端开发 Java
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
JavaFX是Java的下一代图形用户界面工具包。JavaFX是一组图形和媒体API,我们可以用它们来创建和部署富客户端应用程序。 JavaFX允许开发人员快速构建丰富的跨平台应用程序,允许开发人员在单个编程接口中组合图形,动画和UI控件。本文详细介绍了JavaFx的常见用法,相信读完本教程你一定有所收获!
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
|
27天前
|
自然语言处理 Java 关系型数据库
Java mysql根据很长的富文本如何自动获取简介
通过使用Jsoup解析富文本并提取纯文本,然后根据需要生成简介,可以有效地处理和展示长文本内容。该方法简单高效,适用于各种应用场景。希望本文对您在Java中处理富文本并生成简介的需求提供实用的指导和帮助。
39 9
|
2月前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
158 26
|
13天前
|
前端开发 Java 开发工具
Git使用教程-将idea本地Java等文件配置到gitte上【保姆级教程】
本内容详细介绍了使用Git进行版本控制的全过程,涵盖从本地仓库创建到远程仓库配置,以及最终推送代码至远程仓库的步骤。
23 0
|
Java 关系型数据库 MySQL
|
4月前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
354 6