MySQL: 2、SQL语言
一、SQL的简介:
1.SQL的概念:
SQL就是结构化查询语言,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统
2.SQL的作用:
- 是所有关系型数据库的统一查询规范,不同的关系型数据库都支SQL
- 不同数据库之间的SQL也有一些区别,这个称为 方言
3.SQL的注释方式:
-- 空格 单行注释
/* */ 多行注释
# MySql特有的单行注释
二、SQL的分类
分类 说明
三、DDL数据定义语言:操作数据库、表
DDL操作数据库
1、创建数据库
create database 数据库名; -- 创建指定名称的数据库
create database 数据库名 character set 字符集; -- 创建指定名称的数据库并指定字符集
ps: 如果没设置字符集,那么数据库默认使用的是Latin1字符集,也就是ISO-8859-1。
该数据库下的表也会使用该字符集
2、查看、选择数据库
use 数据库; -- 切换数据库
select database(); -- 查看当前正在使用的数据库
show databases; -- 查看MySQL中都有哪些数据库
show create database 数据库名; -- 查看一个数据库的定义信息
datetime 日期类型,显示为 yyyy-MM-dd HH:mm:ss
2、创建表
create table 表名(
字段名1 字段类型(长度),
字段名2 字段类型 -- 注意最后一列不需要加逗号
)ENGINE=InnoDB DEFAULT CHARSET = utf8;
3、查看表
show tables; -- 查看当前数据库中所有的表名
desc 表名; -- 查看数据库表的结构
show create table 表名; -- 查看表的字符集
4、删除表
drop table 表名; -- 从数据库中删除表
drop table if exists 表名;-- 判断表是否存在,存在就删除,不存在就不删除
5、修改表
rename table 旧表名 to 新表名; -- 修改表名
alter table 表名 character set 字符集; -- 修改表的字符集
alter table 表名 add 字段名 字段类型; -- 向表中添加字段
alter table 表名 modify 字段名 字段类型; -- 修改表中字段的数据类型或者长度
alter table 表名 change 旧字段名 新字段名 类型(长度); -- 修改字段名
alter table 表名 drop 字段名; -- 删除字段名
四、DML数据操作语言:操作表中数据
1、往表中插入数据
方式1:插入全部字段,并将所有字段名都写出来
insert into 表名 (字段名1,字段名2...) values(字段值1,字段值2...);
方式2:插入全部字段,但是不写字段名
insert into 表名 values(字段值1,字段值2...);
方式3:指定插入字段的值
insert into 表名 (字段名1) values(字段值1);
ps: 1. varchar char date 类型的值必须使用单引或者双引号
2. 如果插入空盒子,可以忽略不写或者插入null
2、更改表中数据的值
方式1: 不带条件的修改,也就是修改全部字段的数据
update 表名 set 列名 = 值;
方式2:带条件的修改
update 表名 set 列名 = 值 where 条件表达式:字段名 = 值;
update 表名 set 列名 = 值,列名 = 值 where 条件表达式:字段名 = 值;
3、删除表中的数据
方式1: 删除表中所有数据
delete from 表名;
truncate table 表名;
ps:着两种都是直接删除表中所有的数据,但这两种又有些区别
delete from 表名; --》 有多少条记录就执行多少次删除操作,效率低
truncate table 表名; --》 先删除整张表,然后再重新创建一张一模一样的表,效率高
方式2: 跟进条件删除数据
delete from 表名 where 字段名 = 值;
五、DQL数据查询语言:查询表中的数据
1、简单查询
1. 查询表中多少有数据:
select * from 表名;
2. 查询表中的所有记录,但仅显示特定的字段
select 字段1,字段2 from 表名;
3. 查询表中的数据,并将列名用其他别名显示
select
eid AS '编号',
ename AS '姓名',
sex AS '性别',
salary AS '薪资',
hire_date '入职时间', -- AS 可以省略
dept_name '部门名称'
FROM emp;
4. 查询表中的数据,并去掉重复的数据
-- 使用distinct 关键字,去掉重复部门信息
SELECT DISTINCT dept_name FROM emp;
5. 查询表中的数据,并将查询结果参与运算
SELECT ename , salary + 1000 FROM emp;
2、条件查询
如果查询语句中没有设置条件,就会查询所有的行信息,在实际应用中,
一定要指定查询条件,对记录进行过滤
select 列名 from 表名 where 条件表达式;
* 先取出表中的每条数据,满足条件的数据就返回,不满足的就过滤掉
1.比较运算符:

2.逻辑运算符

3.模糊查询、通配符

# 查询含有'精'字的所有员工信息
SELECT * FROM emp WHERE ename LIKE '%精%';
# 查询以'孙'开头的所有员工信息
SELECT * FROM emp WHERE ename LIKE '孙%';
# 查询第二个字为'兔'的所有员工信息
SELECT * FROM emp WHERE ename LIKE '_兔%';
# 查询没有部门的员工信息
SELECT * FROM emp WHERE dept_name IS NULL;
-- SELECT * FROM emp WHERE dept_name = NULL; 错误方式
# 查询有部门的员工信息
SELECT * FROM emp WHERE dept_name IS NOT NULL;
MySQL: 2、SQL语言的更多相关文章
- MySQL的sql语言分类DML、DQL、DDL、DCL、
MySQL的sql语言分类DML.DQL.DDL.DCL. SQL语言一共分为4大类:数据定义语言DDL,数据操纵语言DML,数据查询语言DQL,数据控制语言DCL 1.数据定义语言DDL(Data ...
- MySQL的sql语言分类DML、DQL、DDL、DCL
SQL语言一共分为4大类:数据定义语言DDL,数据操纵语言DML,数据查询语言DQL,数据控制语言DCL 1.数据定义语言DDL(Data Definition Language) 对象: 数据库和表 ...
- Mysql学习---SQL语言的四大分类
SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL. 1. 数据查询语言DQL 数据查询语言DQL基本结构是由SELECT子句,FROM子句,WHE ...
- 使用mysql,sql语言删除冗余信息
这是表,我们需要操作的就是删除除了学号不同,其它信息都相同的冗余信息 思路:删除表格class3中的冗余的stu_id信息,那么接下来我们应该去筛选哪些stu_id信息是冗余的, 此时我们想到的就是利 ...
- 自学SQL语言的例子(使用MySQL实现)
SQL语言作为一种数据库管理的标准语言有着极为广泛的应用场景,菜鸟入门选用的数据库软件是轻量级的免费(这个极为重要)的MySQL,下载链接如下:http://www.mysql.com/downloa ...
- MySQL从删库到跑路(三)——SQL语言
作者:天山老妖S 链接:http://blog.51cto.com/9291927 一.SQL语言简介 1.SQL语言简介 SQL是结构化查询语言(Structured Query Language) ...
- 【MySQL笔记】SQL语言四大类语言
SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL. 1. 数据查询语言DQL 数据查询语言DQL基本结构是由SELECT子句,FROM子句, ...
- MySQL入门——MySQL数据库和SQL语言
MySQL入门——MySQL数据库和SQL语言 摘要:本文主要了解了MySQL关系型数据库和SQL语言的基本知识. MySQL数据库 简介 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB ...
- mysql数据库基本操作sql语言
mysql的启动与关闭 启动 /etc/init.d/mysql start 多实例使用自建脚本启动 2种关闭数据库方法 mysqladmin -uroot -p密码 shutdown #优雅关闭/e ...
- MySQL中的SQL语言
从功能上划分,SQL 语言可以分为DDL,DML和DCL三大类.1. DDL(Data Definition Language)数据定义语言,用于定义和管理 SQL 数据库中的所有对象的语言 :CRE ...
随机推荐
- ZK的watch机制
1.watcher原理框架 由图看出,zk的watcher由客户端,客户端WatchManager,zk服务器组成.整个过程涉及了消息通信及数据存储. zk客户端向zk服务器注册watcher的同时, ...
- curl报错60的问题
使用curl发请post请求的时候,会遇到如下错误: curl: (60) SSL certificate problem: self signed certificate More details ...
- Linux bpytop工具介绍
一.工具简介: Easy to use, with a game inspired menu system. Full mouse support, all buttons with a highli ...
- 使用Wasserstein GAN生成小狗图像
一.前期学习经过 GAN(Generative Adversarial Nets)是生成对抗网络的简称,由生成器和判别器组成,在训练过程中通过生成器和判别器的相互对抗,来相互的促进.提高.最近一段时间 ...
- Just an Old Puzzle(2019多校1007)
Problem Description You are given a 4 × 4 grid, which consists of 15 number cells and an empty cell. ...
- Java 与 Mysql连接,并分页显示
这是我第一个上规模的Java项目,我们必须在一周内完成的作业,零基础学习Java,网上收集了很多资料,逐渐对面向对象的思想有所了解,但还是半灌水,后期打算结合项目系统地学习一遍Java.老师布置的任务 ...
- 最小发射功率下WSN的连通性和覆盖率
简述: 实验要求我们将传感器节点随机均匀分布在1x1的方格中,然后计算节点的最小共同发射功率(COMPOW),保证网络刚好连通,并计算出这些节点的覆盖率.为了解决这个问题,我们的做法是随机均匀部署10 ...
- Activiti7 获取资源信息及其查询流程历史信息
获取资源信息 /** * 获取资源信息 * * @throws IOException */ @Test public void getProcessResources() throws IOExce ...
- 极简显示sessionid的jsp程序 war下载
下载地址:https://files.cnblogs.com/files/xiandedanteng/simpleJspSessionId20200103.zip 解压后得到myweb.war就是可以 ...
- synchronized的实现原理——锁膨胀过程
@ 目录 前言 正文 偏向锁 轻量锁 批量重偏向 批量撤销 重量锁 总结 前言 上一篇分析了优化后的synchronized在不同场景下对象头中的表现形式,还记得那个结论吗?当一个线程第一次获取锁后再 ...