前言
记录于此,方便自己回忆。
正文
我这以Window版的phpstudy软件验证。
需要进入这个目录,才可以使用mysql命令
D:\phpstudy_pro\Extensions\MySQL5.7.26\bin
进入正文
创建info表,列表结构和数据如下
mysql> desc info; +-------+--------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+--------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(100) | YES | | NULL | | | page | int(11) | YES | | 100 | | +-------+--------------+------+-----+---------+-------+ 3 rows in set (0.00 sec) mysql> select * from info; +----+------------+------+ | id | name | page | +----+------------+------+ | 1 | 笔友城堡 | 100 | | 2 | 笔友城堡3 | 100 | | 3 | dushu | 4 | | 4 | shu | 66 | | 5 | shuuu | 300 | | 6 | NULL | 120 | | 7 | NULL | 170 | | 8 | NULL | 173 | +----+------------+------+ 8 rows in set (0.00 sec)
case when使用
不输入分好就可以不断的输入
mysql> select -> case -> when page>= 150 then 'nice' -> when page>= 50 then 'good' -> else 'bad' -> end -> from info; +--------+ | good | | good | | bad | | good | | nice | | good | | nice | | nice | +--------+ 8 rows in set (0.00 sec)
下面添加”评价”
mysql> select -> case -> when page>= 150 then 'nice' -> when page>= 50 then 'good' -> else 'bad' -> end as '评价' -> from info; +--------+ | 评价 | +--------+ | good | | good | | bad | | good | | nice | | good | | nice | | nice | +--------+ 8 rows in set (0.01 sec)
排序
通过SELECT命令显示的记录顺序是不规则的,如果需要按照一定顺序的显示,则需要添加一定条件。
升序
select * from 表名 order by 排序的列名;
下面按照page大小排序
# 或者 select * from info order by page asc; mysql> select * from info order by page; +----+------------+------+ | id | name | page | +----+------------+------+ | 3 | dushu | 4 | | 4 | shu | 66 | | 1 | 笔友城堡 | 100 | | 2 | 笔友城堡3 | 100 | | 6 | NULL | 120 | | 7 | NULL | 170 | | 8 | NULL | 173 | | 5 | shuuu | 300 | +----+------------+------+ 8 rows in set (0.00 sec)
默认是升序,按照值大小。但如果想明确指定按升序排列,就需要像下面这样给命令加上ASC,效果跟上面一样。
降序
如果你想降序排序,那么使用desc。
如下,降序排列。
mysql> select * from info order by page desc; +----+------------+------+ | id | name | page | +----+------------+------+ | 5 | shuuu | 300 | | 8 | NULL | 173 | | 7 | NULL | 170 | | 6 | NULL | 120 | | 1 | 笔友城堡 | 100 | | 2 | 笔友城堡3 | 100 | | 4 | shu | 66 | | 3 | dushu | 4 | +----+------------+------+ 8 rows in set (0.00 sec)
当然如果要限制个数,可以在后面添加limit
# 降序 select * from info order by page desc limit 2; # 增序1 select * from info order by page asc limit 2; # 增序2 select * from info order by page limit 2;
指定查询范围
limit可以现在显示的个数,而offset可以指定偏移的位置。
offset必须跟limit配合使用
# 查询所有的数据 mysql> select * from info order by page asc; +----+------------+------+ | id | name | page | +----+------------+------+ | 3 | dushu | 4 | | 4 | shu | 66 | | 1 | 笔友城堡 | 100 | | 2 | 笔友城堡3 | 100 | | 6 | NULL | 120 | | 7 | NULL | 170 | | 8 | NULL | 173 | | 5 | shuuu | 300 | +----+------------+------+ 8 rows in set (0.00 sec) # 只显示2条记录 mysql> select * from info order by page asc limit 2; +----+-------+------+ | id | name | page | +----+-------+------+ | 3 | dushu | 4 | | 4 | shu | 66 | +----+-------+------+ 2 rows in set (0.00 sec) # 偏移3个位置,只显示2条记录 mysql> select * from info order by page asc limit 2 offset 3; +----+------------+------+ | id | name | page | +----+------------+------+ | 2 | 笔友城堡3 | 100 | | 6 | NULL | 120 | +----+------------+------+ 2 rows in set (0.00 sec)
使用offset之后,查询的2条数据只偏移3个位置之后的。
分组显示
mysql> select * from salary; +-------+-------+-------+ | empid | sales | month | +-------+-------+-------+ | A103 | 101 | 4 | | A102 | 54 | 5 | | A104 | 181 | 4 | | A101 | 184 | 4 | | A103 | 17 | 5 | | A101 | 300 | 5 | | A102 | 205 | 6 | | A104 | 93 | 5 | | A103 | 12 | 6 | | A107 | 87 | 6 | +-------+-------+-------+ 10 rows in set (0.00 sec) mysql> mysql> select * from salary group by empid; ERROR 1055 (42000): Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'company.salary.sales' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by mysql>
由于我这提示不支持,是MySQL版本不支持,需要修改配置。具体可看《》或《》
暂时不看 group by相关内容,略过。
我还会回来的!
update
不指定条件
update 表名 set 列名 = 新数据;
这种方式无异于删库提桶跑路,因为所有的列名的数据都会更新。
不推荐!
指定条件
update 表名 set 列名 = 新数据 where 查询条件;
示范一下
# 更新数据 mysql> update info set name = "biu" where page=173; # 查询更新后的所有数据 mysql> select * from info; +----+------------+------+ | id | name | page | +----+------------+------+ | 1 | 笔友城堡 | 100 | | 2 | 笔友城堡3 | 100 | | 3 | dushu | 4 | | 4 | shu | 66 | | 5 | shuuu | 300 | | 6 | NULL | 120 | | 7 | NULL | 170 | | 8 | biu | 173 | +----+------------+------+
当然,按照书中的例子,先添加一列
# 添加新的mark列 alter table info add mark varchar(100); # 查询所有数据 mysql> select * from info; +----+------------+------+------+ | id | name | page | mark | +----+------------+------+------+ | 1 | 笔友城堡 | 100 | NULL | | 2 | 笔友城堡3 | 100 | NULL | | 3 | dushu | 4 | NULL | | 4 | shu | 66 | NULL | | 5 | shuuu | 300 | NULL | | 6 | NULL | 120 | NULL | | 7 | NULL | 170 | NULL | | 8 | biu | 173 | NULL | +----+------------+------+------+ # 指定条件更新mark值 mysql> update info set mark = "nice" where page> 150; # 查询所有数据 mysql> select * from info; +----+------------+------+------+ | id | name | page | mark | +----+------------+------+------+ | 1 | 笔友城堡 | 100 | NULL | | 2 | 笔友城堡3 | 100 | NULL | | 3 | dushu | 4 | NULL | | 4 | shu | 66 | NULL | | 5 | shuuu | 300 | nice | | 6 | NULL | 120 | NULL | | 7 | NULL | 170 | nice | | 8 | biu | 173 | nice | +----+------------+------+------+
当然,新增了一列,如果不需要了,可以删除,然后就能恢复到默认值。
alter table info drop mark;
delete
delete命令虽然会删除记录,但它并不会删除表的列结构。删除表本身时需要使用drop table命令。
delete from 表名; 删除数据内容
drop table 表名 or drop table if exists 表名 ; 删除列结构和数据
删除所有数据
delete from 表名;
删除指定条件的数据
delete from 表名 where 限定条件;
比如
# 删除page> 200的数据 delete from info4 where page> 200;
参考文章
© 版权声明