〇、总结

1、

一、数据库的基本概念

1、概念

  • 用于存储和管理数据的仓库
  • 特点:
    • 持久化存储,本质是文件系统
    • 方便存储和管理数据
    • 使用统一方式(MySQL)操作
  • 常见的数据库软件:
    • MySQL:Oracle->SUN,6以后收费
    • Oracle:Oracle,收购Java所在的SUN公司,收费
    • SQL Server
    • DB2:IBM,大型,银行
    • SQLite:嵌入式开发,如浏览器内置,安卓操作系统

二、MySQL数据库软件

1、安装

  • 成功后在cmd测试:mysql -uroot -proot
  • 退出:exit/quit
  • 服务器连接:mysql  -h127.0.0.1 -uroot -proot
  • 详细版:mysql --host=127.0.0.1 --user=root --password=root
  • 配置:
    • 可以改为手动启动cmd--services.msc
    • 启动:net strart mysql
    • 停止服务:net stop mysql

      

三、SQL语句

1、概念

  • Structured Query Language:结构化查询语言
  • 关系型数据库都可以使用SQL语句操作

2、通用语法

  • 单行或多行书写,每条语句以分号结尾
  • 适当使用空格和缩进提高可读性
  • 不区分大小写,建议大写
  • 注释:
    • 单行注释:--
    • 多行注释:/* */
    • 特有注释:#
  • 语句
    • show databses; # 查看数据库个数

3、SQL语句分类

  • Data Definition Language (DDL 数据定义语言)
  • Data Manipulation Language(DML 数据操纵语言)
  • Data Query Language(DQL 数据查询语言)
  • Data Control Language(DCL 数据控制语言)

4、DDL操作数据库

  • C

 

  • R

     

  • U

  • D

  • 使用后不允许show只允许select

5、DDL操作表

  • C

    • 数据类型

      • timestamp时间戳,与date类型的区别在于有默认值
      • varchar(n):最大n个字符
      • blob:大文本
      • binary:大型图片
  • R
    • 查询表名:show tables;
    • 查询表结构:desc 表名;
  • U
    • 改表名

    • 修改表的字符集:alter table stu character set utf8;
    • 添加列:alter table 表名 add 列名 数据类型;
    • 修改列名:alter table 表名 change 列名 新列名 新的类型;
    • 改类型:alter table 表名 modify 列名 新的数据类型;
    • 删除列:alter table 表名 drop 列名;      
  • D

6、DML,数据操纵语言

  • 增加

    • 除了数字类型,均需使用双引号括起来      
  • 删除
    • delete:逐行删除
    • truncate:先删表,再创建
  • 修改

5、DQL:查询记录

  • 语法(wghol):where ... group by ... having ... order by ... limit...
  • 基础查询:
    • 多字段
    • 去重
    • 计算列:ifnull(表达式1,表达式2)
    • 起别名as
  • 条件查询
    • 模糊查询:_和%
USE DB1;
DESC STU;
INSERT INTO STU (ID,NAME,AGE) VALUES(1,"张三",23);
SELECT * FROM STU;
INSERT INTO STU VALUES (2,"张无忌",19,99.7,NULL,NULL);
INSERT INTO stu VALUES(3,'张三丰',27,98.5,'1991-11-11',NULL);
DELETE FROM stu WHERE id=1;
DELETE FROM stu;
TRUNCATE TABLE STU;-- 删除表,然后再创建一个一模一样的空表
SELECT * FROM STU;
UPDATE STU SET AGE=117 WHERE NAME="张三丰";
UPDATE STU SET AGE=48, SCORE=96 WHERE NAME="张三";
UPDATE STU SET AGE=20;
CREATE TABLE student (
id INT, -- 编号
NAME VARCHAR(20), -- 姓名
age INT, -- 年龄
sex VARCHAR(5), -- 性别
address VARCHAR(100), -- 地址
math INT, -- 数学
english INT -- 英语
);
INSERT INTO student(id,NAME,age,sex,address,math,english) VALUES (1,'马云',55,'男','
杭州',66,78),(2,'马化腾',45,'女','深圳',98,87),(3,'马景涛',55,'男','香港',56,77),(4,'柳岩',20,'女','湖南',76,65),(5,'柳青',20,'男','湖南',86,NULL),(6,'刘德华',57,'男','香港',99,99),
(7,'马德',22,'女','香港',99,99),(8,'德玛西亚',18,'男','南京',56,65); SELECT * FROM student; -- 公司一般不允许写*,要求全部写出来
-- 查询姓名和你年龄
SELECT
NAME,-- 姓名
AGE -- 年龄
FROM
STUDENT;-- 学生表
-- 去除重复的结果
SELECT DISTINCT ADDRESS FROM STUDENT; SELECT DISTINCT NAME,ADDRESS FROM STUDENT;
-- 计算math和 English的分数之和
SELECT NAME,MATH,ENGLISH,ENGLISH+MATH FROM STUDENT;
SELECT NAME,MATH 数学,ENGLISH 英语,IFNULL(ENGLISH,0)+MATH AS 总分 FROM STUDENT;
SELECT NAME,MATH,ENGLISH,IFNULL(ENGLISH,0)+MATH 总分 FROM STUDENT; SELECT * FROM STUDENT;
-- 查询年龄大于20岁
SELECT * FROM STUDENT WHERE AGE>20;
SELECT * FROM STUDENT WHERE AGE>=20;
-- 查询年龄等于20岁
SELECT * FROM STUDENT WHERE AGE=20;
-- 查询年龄不等于20岁
SELECT * FROM STUDENT WHERE AGE!=20;
-- 或
SELECT * FROM STUDENT WHERE AGE <> 20; -- 查询年龄>=20且<=30
SELECT * FROM STUDENT WHERE AGE>=20 AND AGE<=30;
-- BETWEEN A AND B
SELECT * FROM STUDENT WHERE AGE BETWEEN 20 AND 30; -- 查询年龄为22岁,19岁,25岁的信息
SELECT * FROM STUDENT WHERE AGE=18 OR AGE=22 OR AGE=25;
SELECT * FROM STUDENT WHERE AGE IN (22,18,25); -- 查询英语缺考
SELECT * FROM STUDENT WHERE ENGLISH=NULL;-- 错误的,null值不能使用等号=或不等号!=/<>判断
SELECT * FROM STUDENT WHERE ENGLISH IS NULL;
-- 查询英语没有缺考的
SELECT * FROM STUDENT WHERE ENGLISH IS NOT NULL; -- 查询姓马的
SELECT * FROM STUDENT WHERE NAME LIKE '马%' ;
-- 查询第二个字是华的人
SELECT * FROM STUDENT WHERE NAME LIKE '_化%' ;
-- 查询姓名是三个字的人
SELECT * FROM STUDENT WHERE NAME LIKE '___' ; -- 查询姓名中包含马的人
SELECT * FROM STUDENT WHERE NAME LIKE '%马%' ;
SELECT * FROM STUDENT WHERE NAME LIKE '%德%' ;

【Java EE】Day02 MySQL概念、软件、语句的更多相关文章

  1. 点评阿里JAVA手册之MySQL数据库 (建表规约、索引规约、SQL语句、ORM映射)

    下载原版阿里JAVA开发手册  [阿里巴巴Java开发手册v1.2.0] 本文主要是对照阿里开发手册,注释自己在工作中运用情况. 本文内容:MySQL数据库 (建表规约.索引规约.SQL语句.ORM映 ...

  2. Eclipse for Java EE软件操作集锦(一)

    以下是我在Java网站开发过程中,关于软件操作Eclipse中,遇到的一些问题并提供了解决方案.一.java web开发使用的集成开发工具是eclipse for Java EE 官方下载地址:htt ...

  3. java的几个版本以及jre,jdk等概念——【转载】JDK、Java SE、Java EE、Java ME我该选

    我们平时使用的一些软件,有一部分需要Java环境的支持,但是SUN那么多的产品,让人眼花缭乱的版本号,前看后看都差不多的缩写,让我们选择起来的时候常常望而却步,只好跟着感觉走.所以下面我要介绍的就是那 ...

  4. 疯狂软件对Oracle放弃Java EE的看法

    近日网络上出现了一些关于Oracle将要放弃Java EE的说法,在Java行业引起不小的关注,甚至有些人开始担心Java会不会就此消亡,但事实上这不过是杞人忧天,疯狂软件教学总监李刚根据多年来Jav ...

  5. day02 mysql基本语句 存储引擎 数据类型 完整性约束

    day02 mysql   一.sql的基本语句     系统数据库         information_schema: 虚拟库, 不占磁盘空间(在内存汇中): 存的是数据库启动后的一些参数, 如 ...

  6. 【软件安装与配置】【Java】Eclipse For Java EE的安装

    Eclipse For Java EE的安装 哔哩哔哩:萌狼蓝天 微信公众号:萌狼蓝天 博客:萌狼工作室 00 提前说明 因为编程涉及的环境配置资源比较多,所以我专门创建了一个文件夹(Developm ...

  7. 【JAVA EE企业级开发四步走完全攻略】

    本文是J2EE企业级开发四步走完全攻略索引,因内容比较广泛,涉及整个JAVA EE开发相关知识,这是一个长期的计划,单个发blog比较零散,所以整理此索引,决定以后每发一季JAVA EE blog后会 ...

  8. JAVA EE企业级开发四步走完全攻略 [转]

    http://bbs.51cto.com/thread-550558-1.html 本文是J2EE企业级开发四步走完全攻略索引,因内容比较广泛,涉及整个JAVA EE开发相关知识,这是一个长期的计划, ...

  9. 最重要的 Java EE 最佳实践

    參考:IBM WebSphere 开发人员技术期刊: 最重要的 Java EE 最佳实践 IBM WebSphere 开发人员技术期刊: 最重要的 Java EE 最佳实践 2004 年 IBM® W ...

  10. day02 MySQL基本操作

    day02 MySQL基本操作 昨日内容回顾 数据库演变史 1.纯文件阶段 2.目录规范 3.单机游戏 4.联网游戏 # 数据库就是一款帮助我们管理数据的程序 软件开发架构及数据库本质 cs架构与bs ...

随机推荐

  1. ProxySQL 读写分离方法

    转载自:https://www.jianshu.com/p/597b840bf70c (使用正则表达式实现基本的读/写分离) 在这一部分,我将通过一个示例来演示如何通过正则表达式来实现读/写分离. 首 ...

  2. 安装ceph (快速) 步骤二:存储集群

    用 ceph-deploy 从管理节点建立一个 Ceph 存储集群,该集群包含三个节点,以此探索 Ceph 的功能. 创建一个 Ceph 存储集群,它有一个 Monitor 和两个 OSD 守护进程. ...

  3. 最佳实践:4个黄金指标和USE方法

    Prometheus鼓励用户监控所有的东西,首先是及时发现问题其次是要能够快速对问题进行定位. 4个黄金指标 4个黄金指标可以在服务级别帮助衡量终端用户体验.服务中断.业务影响等层面的问题. 主要关注 ...

  4. nginx干货文档

    文档地址:https://files.cnblogs.com/files/sanduzxcvbnm/跟冰河学习Nginx技术.pdf

  5. Netty 学习(八):新连接接入源码说明

    Netty 学习(八):新连接接入源码说明 作者: Grey 原文地址: 博客园:Netty 学习(八):新连接接入源码说明 CSDN:Netty 学习(八):新连接接入源码说明 新连接的接入分为3个 ...

  6. ArcMap布局添加图表问题

    在ArcMap分析制图过程中,经常会产生一些图表,然而在布局中添加这些图表会发现一些意想不到的问题. 问题重现 将图表直接添加到布局会发现图表有黑底,这在我们布局出图中是十分不美观的,这该如何解决呢? ...

  7. 关于aws-Lambda的cron周期性计划任务-表达式的定义方式

    关于aws-Lambda的cron周期性定时任务的定义方式,与其他系统或者语言可能略有差异 区别之一,就是Lambda是6个字段的, (分,时,日,月,周,年),多了一个年份字段,各字段之间使用空格隔 ...

  8. Vue3解决ElementPlus Drawer或弹出对话框不生效的问题

    第一时间检查你是否还在使用 :visible.sync="drawer" 来绑定事件框的隐藏和显示,vue3.0 已经更改为通过 v-model 来绑定事件框的显示与隐藏.

  9. 监控 HTTP 服务器的状态(测试返回码)shell脚本

    #!/bin/bash # 监控 HTTP 服务器的状态(测试返回码) # 设置变量,url为你需要检测的目标网站的网址(IP 或域名),比如百度 url=http://http://183.232. ...

  10. 关于Springboot启动报错 Whitelabel Error Page: This application has no explicit mapping

    Whitelabel Error Page This application has no explicit mapping for /error, so you are seeing this as ...