命令行
1、显示当前数据库服务器中的数据库列表:mysql>SHOW DATABASES
2、建立数据库:mysql>CREATE DATABASE 库名
3、建立数据表:mysql>USE 库名mysql>CREATE TABLE 表名 (字段名 VARCHAR(20), 字段名 CHAR(1))
4、删除数据库:mysql>DROP DATABASE 库名
5、删除数据表:mysql>DROP TABLE 表名;
6、将表中记录清空:mysql>DELETE FROM 表名
7、往表中插入记录:mysql>INSERT INTO 表名 VALUES ("hyq","M")
8、更新表中数据:mysql->UPDATE 表名 SET 字段名1='a',字段名2='b' WHERE 字段名3='c'
9、用文本方式将数据装入数据表中:mysql>load data local infile "d:/mysql.txt" into table 表名
10、导入.sql文件命令:mysql>USE 数据库名mysql>source d:/mysql.sql
11、命令行修改root密码:mysql>update mysql.user set password=password('新密码') where user='root'mysql>flush privileges
12.修改密码的三种方法:mysql>update user set password=password('123456') where user='joy_pen'mysql>flush privilegesmysql>set password for 'joy_oen'=password('123456')mysql>grant usage on *.* to 'joy_pen' identified by '123456'
1、创建数据库
命令:create database <数据库名> 例如:建立一个名为xhkdb的数据库mysql>create database xhkdb
2、显示所有的数据库
命令:show databases (注意:最后有个s)mysql>show databases
3、删除数据库
命令:drop database <数据库名> 例如:删除名为 xhkdb的数据库mysql>drop database xhkdb
4、连接数据库
命令: use <数据库名> 例如:如果xhkdb数据库存在,尝试存取它:mysql>use xhkdb 屏幕提示:Database changed
5、当前选择(连接)的数据库mysql>select database()
6、当前数据库包含的表信息:mysql>show tables(注意:最后有个s)
三、表 *** 作, *** 作之前应连接某个数据库
1、建表
命令:create table <表名>( <字段名1><类型1>[,..<字段名n><类型n>])
mysql>create table MyClass(
>id int(4) not null primary key auto_increment,
>name char(20) not null,
>sex int(4) not null default ''0'',
>degree double(16,2))
2、获取表结构
命令: desc 表名,或者show columns from 表名
mysql>DESCRIBE MyClass
mysql>desc MyClass
mysql>show columns from MyClass
3、删除表
命令:drop table <表名>
例如:删除表名为 MyClass 的表 mysql>drop table MyClass
4、插入数据
命令:insert into <表名>[( <字段名1>[,..<字段名n >])] values ( 值1 )[, ( 值n )]
例如,往表 MyClass中插入二条记录, 这二条记录表示:编号为1的名为Tom的成绩为96.45, 编号为2 的名为Joan 的成绩为82.99,编号为3 的名为Wang 的成绩为96.5.
mysql>insert into MyClass values(1,'Tom',96.45),(2,'Joan',82.99), (2,'Wang', 96.59)
5、查询表中的数据
1)、查询所有行
命令: select <字段1,字段2,...>from <表名 >where <表达式 >
例如:查看表 MyClass 中所有数据 mysql>select * from MyClass
2)、查询前几行数据
例如:查看表 MyClass 中前2行数据
mysql>select * from MyClass order by id limit 0,2
6、删除表中数据
命令:delete from 表名 where 表达式
例如:删除表 MyClass中编号为1 的记录
mysql>delete from MyClass where id=1
7、修改表中数据:update 表名 set 字段=新值,… where 条件
mysql>update MyClass set name=''Mary'' where id=1
8、在表中增加字段:
命令:alter table 表名 add 字段 类型 其他
例如:在表MyClass中添加了一个字段passtest,类型为int(4),默认值为0
mysql>alter table MyClass add passtest int(4) default ''0''
9、更改表名:
命令:rename table 原表名 to 新表名
例如:在表MyClass名字更改为YouClass
mysql>rename table MyClass to YouClass
更新字段内容
update 表名 set 字段名 = 新内容
update 表名 set 字段名 = replace(字段名,''旧内容'',''新内容'')
UNION在mysql中被称为集合 *** 作, *** 作类型分为两种:UNION DISTINCT 和 UNION ALL;注意:UNION和UNION DISTINCT是一样的功能。UNION功能为合并多个查询的结果并去重,UNION ALL的功能为合并多个查询的结果不去重。
集合 *** 作时,两边的输入必须拥有相同的列数,如果数据类型不同的话,mysql会自动进行隐式转化 ;同时,结果列的名称由第一个查询的列的名称决定。下面看一下例子:
sql语句为:SELECT 'abc' as o,'haha' as p,4 as q FROM DUAL UNION SELECT 'abc' as a,'haha',4 FROM DUAL结果是:
如果是:SELECT 'abc' as o,'haha' as p,4 as q FROM DUAL UNION ALL SELECT 'abc' as a,'haha',4 FROM DUAL
如果两次查询的列个数不一致,如:SELECT 'abc' as o,'haha' as p,4 as q FROM DUAL UNION ALL SELECT 'abc' as a,'haha' FROM DUAL
在多个列查询时,只要有一个列的数据不一致时,都是无法去重的;也就是去重是每个列的数据完全一致,比如:SELECT 'abc' as o,'haha' as p,4 as q FROM DUAL UNION DISTINCT SELECT 'abc' as a,'haha',5 FROM DUAL
这几个例子可以看出UNION (DISTINCT) 与 UNION ALL的用法了吧,下面讲一下UNION (DISTINCT)的实现方式:
一:创建一张虚拟表;
二:对这张虚拟表的列添加唯一索引,即UNIQUE INDEX
三:将结果插入虚拟表
四:返回虚拟表
如何判断是否创建一个虚拟表,我们可以通过一下语句判断:
SHOW STATUS LIKE 'Created_tmp_tables'
SELECT 'abc' as o,'haha' as p,4 as q FROM DUAL UNION SELECT 'abc' as a,'haha',4 FROM DUAL
SHOW STATUS LIKE 'Created_tmp_tables' 结果是:
可见结果3比结果1多1,在 *** 作第二个 UNION语句时创建了一个虚拟表;如果UNION创建了索引,插入会相对变慢
# SELECT 数据查询
## 基础
显示如何使用简单的`select`语句查询单个表中的数据 使用`SELECT`语句从表或视图获取数据。
表由行和列组成,如电子表格。 通常,我们只希望看到子集行,列的子集或两者的组合。
SELECT语句的结果称为结果集,它是行列表,每行由相同数量的列组成。
select 语法
SELECT语句由以下列表中所述的几个子句组成:
1. SELECT 之后是逗号分隔列或星号(*)的列表,表示要返回所有列。
2. FROM 指定要查询数据的表或视图。
3. JOIN 根据某些连接条件从其他表中获取数据。
4. WHER E过滤结果集中的行。
5. GROUP BY将一组行组合成小分组,并对每个小分组应用聚合函数。
6. HAVING 过滤器基于GROUP BY子句定义的小分组。
7. ORDER BY 指定用于排序的列的列表。
8. LIMIT 限制返回行的数量。
语句中的`SELECT`和`FROM`语句是必须的,其他部分是可选的。
`SELECT`语句允许通过在`SELECT`子句中指定逗号分隔列的列表来查询表的部分数据
建议显式获取数据的列,原因如下:
1. 使用星号(*)可能会返回不使用的列的数据。 它在MySQL数据库服务器和应用程序之间产生不必要的I/O磁盘和网络流量。
2. 如果明确指定列,则结果集更可预测并且更易于管理。 想象一下,当您使用星号(*)并且有人通过添加更多列来更改表格数据时,将会得到一个与预期不同的结果集。
3. 使用星号(*)可能会将敏感信息暴露给未经授权的用户
格式 `select 列筛选 form table where 行筛选`
还有一些有用的运算符可以在WHERE子句中使用来形成复杂的条件,例如:
>BETWEEN 选择在给定范围之内的值。
>LIKE 匹配基于模式匹配的值。
>IN 指定值是否匹配列表中的任何值。
>IS NULL 检查该值是否为NULL。
## SELECT 子查询
在一个查询过程中 嵌套另一个查询,子查询的结果作为外部查询的条件或者数据范围来使用。
分为 3 类:
1. where 型
- `select展示列名 from 表名 where 列名 运算符[in...] (select 对应列名 from ...)`
- 这个列名 和 对应列名 应该做到类型相同
- 如果不加入运算符 也可使用IN 这些类似的符号 - `select 展示列名 from 表名 where 列名 in (select 对应列名 from ...)`
- ex:
`select 展示列名 from 表名 where 列名 >ALL(select 对应列名 from ....)`
比子查询的值都大
`select 展示列名 from 表名 where 列名 >ANY(select 对应列名 from ....)`
比子查询的任意一个值大
2. from 型
- `select 展示列名 from 表名 inner join (select 列名 from ...) 临时表名 on 条件;`
- 其中,select的子查询所得的表 为临时表,后跟临时表名,可在条件判断中指代
3. exist 型
- `select 展示列 from 表名 where exists (select 列名 from 表名 where 条件)`
- 将主查询的结果带入子查询进行条件判断和匹配,如果查询出结果即保留。
## 去重 DISTINCT
SELECT 语句执行简单的数据查询时,返回的是所有匹配的记录。`distinct` 实现查询不重复的数据
**DISTINCT 关键字的主要作用就是对数据表中一个或多个字段重复的数据进行过滤,只返回其中的一条数据给用户。**
使用 `DISTINCT` 关键字时需要注意以下几点:
- `DISTINCT` 关键字只能在 `SELECT` 语句中使用。
- 在对一个或多个字段去重时,`DISTINCT` 关键字必须在所有字段的最前面。
- 如果 `DISTINCT` 关键字后有多个字段,则会对多个字段进行组合去重,也就是说,只有多个字段组合起来完全是一样的情况下才会被去重。
## 指定别名 AS
### 1. 为表指定别名
1. 当表名很长的时候 或者 执行了一些特殊的查询的时候,为方便 *** 作,可以为表指定一个别名,用以替代原来的名称
2. 语法.
3. `表名>as 别名>` - 含义: - `表名>` : 数据库中存储的数据表名称。
- `别名>` : 查询的时候指定的新的名称。
- `as` : 此关键字 可以 省略,省略之后要将 `表名`与`别名`用 `空格` 分开
** *注意:表的别名不能与该数据库的其它表同名。字段的别名不能与该表的其它字段同名。在条件表达式中不能使用字段的别名,否则会出现“ERROR 1054 (42S22): Unknown column”这样的错误提示信息。* **
*** ex1:
***
### 2. 为字段指定别名
1. 在使用 SELECT 语句查询数据时,MySQL 会显示每个 SELECT 后面指定输出的字段。有时为了显示结果更加直观,我们可以为字段指定一个别名。
2. 语法:
3. `字段名>[AS] 别名>`
- 含义:
- `字段名>`:为数据表中字段定义的名称。
- `字段别名>`:字段新的名称。
- `AS` 关键字可以省略,省略后需要将字段名和别名用空格隔开
** *注意:表别名只在执行查询时使用,并不在返回结果中显示。而字段定义别名之后,会返回给客户端显示,显示的字段为字段的别名* ** ***
ex2:
***
## 限制查询条数 LIMIT
1. LIMIT 关键字有 3 种使用方式,即
- `指定初始位置`、
- `不指定初始位置`
- `OFFSET 组合`使用
(。。。。。 我之前一直不知道, 只会使用 `limit 200`。。。。。)
### 指定初始位置
1. 语法
- `LIMIT 初始位置,记录数`
- 初始位置”表示从哪条记录开始显示;第一条记录的位置是 0,第二条记录的位置是 1。后面的记录依次类推。
- “记录数”表示显示记录的条数。
- *LIMIT 后的两个参数必须都是正整数。
*ex:tb_students_info 表中,使用 LIMIT 子句返回从第 4 条记录开始的行数为 5 的记录,SQL 语句和运行结果如下。
### 不指定初始位置
记录从第一条记录开始显示。显示记录的条数由 LIMIT 关键字指定。
1. 语法
- `LIMIT 5`
- `SELECT * FROM tb_students_info LIMIT 15`
### LIMIT 和 OFFSET 组合使用
1. 语法
- `LIMIT 记录数 OFFSET 初始位置`
- 参数和 LIMIT 语法中参数含义相同,“初始位置”指定从哪条记录开始显示;“记录数”表示显示记录的条数。
该语句返回的是从第 4 条记录开始的之后的 5 条记录。即“ LIMIT 5 OFFSET 3 ”意思是获取从第 4 条记录开始的后面的 5 条记录,和“ LIMIT 3 , 5 ”返回的结果相同。
*** 2021-12-22 今天先学到这里 明天继续 MySql 的查询 学习
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)