创建表格  

先判断users表是否存在,然后设置user_id为无符号(UNSIGNED)自动增长(AUTO_INCREMENT)的整型

并通过PRIMARY KEY设置user_id为主键

ENGINE是指存储引擎为INNODB

CHARSET是指编码格式为utf-8

CREATE TABLE
IF NOT EXISTS `users` (
`user_id` INT UNSIGNED AUTO_INCREMENT,
`user_password` VARCHAR (100) NOT NULL,
PRIMARY KEY (`user_id`)
) ENGINE = INNODB DEFAULT CHARSET = utf8

删除表格

DROP TABLE `users`

插入数据:由于user_id是自增的,所以给定值是0,给其他值会赋值上去

字符串的值必须要加上单引号或者双引号

INSERT INTO `users`(`user_id`,`user_password`) VALUES(0,'nihao')

查询数据:条件user_id<20,查询结果如下图

SELECT * from `users` where `user_id`<20

BINARY的使用:

查询时在where后面使用BINARY可以区分字母大小写,否则不区分

select * from `users` where BINARY `user_password`='Nihao';
select * from `users` where `user_password`='Nihao'

LIMIT的使用:

第一条语句:查询使用LIMIT 2时相当于获取两条数据,

第二条语句:使用LIMIT 1,2时相当于在第一条数据之后开始获取两条数据

第三条语句:LIMIT 1 OFFSET 2相当于从第二条数据之后开始获取一条数据,注意与第二条语句是相反的

select * from `users` where `user_password`='Nihao' LIMIT 2;
select * from `users` where `user_password`='Nihao' LIMIT 1,2;
SELECT * from `users` LIMIT 1 OFFSET 2

使用LIke查询:

%指代在这个字符前所有的字符,_指代单个字符

SELECT * from users where user_password LIKE '%明';
SELECT * from users where user_password LIKE '刘%';
SELECT * from users where user_password LIKE '%德%';
SELECT * from users where user_password LIKE '_明';

UNION的使用:

UNION:将不同表的相同列的相同值展示出来(不包含重复数据)

UNION  ALL:将不同表的相同列的相同值展示出来(包含重复数据)

distinct:可以去除重复数据

SELECT class_id from users where user_password LIKE '%明'
UNION SELECT class_id from classes;
SELECT class_id from users where user_password LIKE '%明'
UNION all SELECT class_id from classes;

查询语句排序:根据order by 后面的字段进行排列,默认asc(升序),而desc是降序

SELECT * from classes ORDER BY class_name desc;

转码:

如果字符集采用utf8的编码格式,想要用拼音排序,先要转码

SELECT * from classes ORDER BY CONVERT(class_name using gbk) desc;

GROUP BY:分组查询

select count(*) from users;
select class_id,count(*) from users GROUP BY class_id;

 with rollup:可以将group by的值最后再统计一遍

 coalesce:如果括号内第一个值为空,后面的值会替代前面的值

select COALESCE(class_id,'总数') as '班级ID',count(*) as '人数'  from users GROUP BY class_id WITH ROLLUP;

 空值处理:

SELECT * from users where class_id is null;
select * from users where class_id is not null;
SELECT *,IFNULL(class_id,4) as '其他' from users;下图是查询出来的结果class_id和其他是同一个项,不同的处理方式,用4代替空值

正则表达式的使用

SELECT * from users where user_password REGEXP '^武';#^查找以武开头的所有数据#
SELECT * from users where user_password REGEXP '易$';#$查找以易结尾的所有数据#
SELECT * from users where user_password REGEXP '苏';#包含苏的所有数据
SELECT * from users where user_password REGEXP '王.';#放在后面就是匹配前面的字符,放在前面就是匹配后面的字符,如王维,用'.维'或'王.'
SELECT * from users where class_id REGEXP '[12]';#包含在[]内的单个字符,中文会出现问题
SELECT * from users where user_password REGEXP '[^苏轼的]';#[^]查找不包含在[]里的字符
SELECT * from users where user_password regexp '武*';#和前面的匹配包含所有数据类似,包括空字符
select * from users where user_password REGEXP '武+';#不包括空字符
select * from users where user_password REGEXP '武?';#*+?类似,后续还待研究
select * from users where user_password REGEXP '白|刘';#匹配多个值

返回值是是否有匹配的,即bool值

SELECT 'asssssas' REGEXP 'as{2}';#正则表达式的{}表示匹配2个s
SELECT 'asssssas' REGEXP 'as{2,}';#正则表达式的{}表示匹配2个s到无数个s
SELECT 'asssssas' REGEXP 'as{2,4}';#正则表达式的{}表示匹配2个s到4个s
SELECT 'asssssas' REGEXP 'a(ss)*';#括号内作为一个整体去匹配

 MySql的执行顺序

  1. FROM, including JOINs
  2. WHERE
  3. GROUP BY
  4. HAVING
  5. WINDOW functions
  6. SELECT
  7. DISTINCT
  8. UNION
  9. ORDER BY
  10. LIMIT and OFFSET

更新语句:使用replace可以批量更改数据

 UPDATE users SET user_password='李白' where user_id=20;
UPDATE users set user_password=REPLACE(user_password,'nihao','刘德华');
SELECT * from users;

删除语句:

delete是DML支持回滚,

truncate和drop是DDL语言不支持回滚

delete  from users where user_id=20;

2021-7-29 MySql的简单使用的更多相关文章

  1. jsp+servlet+mysql 实现简单的银行登录转账功能

    jsp+servlet+mysql 实现简单的银行登录转账功能 [前期的准备] html(登录界面),servlet(处理业务逻辑),jsp(主要实现界面),mysql(实现与数据库的简单的交互)先从 ...

  2. Ubuntu 安装mysql和简单操作

    http://www.cnblogs.com/zhuyp1015/p/3561470.html ubuntu上安装mysql非常简单只需要几条命令就可以完成. 1. sudo apt-get inst ...

  3. mysql定时任务简单例子

    mysql定时任务简单例子 ? 1 2 3 4 5 6 7 8 9     如果要每30秒执行以下语句:   [sql] update userinfo set endtime = now() WHE ...

  4. Mysql的简单使用(三)

    接上文Mysql的简单使用(二) mysql中结构相同的两个表进行合并:(注意需要两个表的结构是一样的) 有如下结构的两个表father和person. 合并的步骤为: 1.把person表和fath ...

  5. PHP 17: MySQL的简单介绍

    原文:PHP 17: MySQL的简单介绍 这一章将简单介绍MySQL的基本知识. 本文来自http://lib.hackbase.com/html/8/35125.htm. MySQL是最受欢迎的开 ...

  6. MySQL的简单使用-(一)

    MySQL的简单使用 使用MySQL命令行工具 Windows 用户使用: MySQL Client, 输入密码 Linux: mysql -u用户名 -p密码 mysql -uroot -p 显示数 ...

  7. mysql安装简单教程(自动安装/配置安装)

    mysql安装简单教程(自动安装/配置安装) 1.1前言: 由于特殊原因,在最近2-3个月里mysql真是安装了无数遍,每次安装都要上网找教程,每个教程基本都不一样,因此还是自己写下来比较好,毕竟自己 ...

  8. python操作三大主流数据库(2)python操作mysql②python对mysql进行简单的增删改查

    python操作mysql②python对mysql进行简单的增删改查 1.设计mysql的数据库和表 id:新闻的唯一标示 title:新闻的标题 content:新闻的内容 created_at: ...

  9. 29.Mysql监控

    29.Mysql监控29.1 如何选择一个监控方案 29.1.1 选择何种监控方式 29.1.2 如何选择合适自己的监控工具29.2 常用网络监控工具 29.2.1 Cacti简介 29.2.2 Na ...

  10. Linux下MySQL的简单操作

    Linux下MySQL的简单操作 更改mysql数据库root的密码 首次进入数据库是不用密码的: [root@localhost ~]# /usr/local/mysql/bin/mysql -ur ...

随机推荐

  1. ECharts 环形饼图配置

    官网文档:https://echarts.apache.org/zh/option.html#series-pie.type 使用案例指导:https://echarts.apache.org/zh/ ...

  2. map和multimap

    map相对于set区别,map具有键值和实值,所有元素根据键值自动排序,pair的第一个值被称为键值key,pair的第二个值被称为实值value.map也是以红黑树为底层实现机制,根据key进行排序 ...

  3. 【asp.net core】自定义模型绑定及其验证

    引言 水此篇博客,依旧是来自群里的讨论,最后说到了,在方法参数自定义了一个特性,用来绑定模型,优先从Form取,如果为空,或者不存在,在从QueryString中获取并且绑定,然后闲着无聊,就水一篇博 ...

  4. 2023-02-23:请用go语言调用ffmpeg,解码mp4文件并保存为YUV420P格式文件。

    2023-02-23:请用go语言调用ffmpeg,解码mp4文件并保存为YUV420P格式文件. 答案2023-02-23: 使用 github.com/moonfdd/ffmpeg-go 库. 解 ...

  5. 如何在Docker Compose中限制容器的CPU和内存使用?

    最近我在使用开源统计Umami过程中,发现CPU和内存经常占满,导致其它服务都不能正常使用.Umami我使用的docker-compose进行部署,于是打算使用docker-compose限制下容器的 ...

  6. sipp重放rtp数据测试FreeSWITCH

    环境:CentOS 7.6_x64 FreeSWITCH版本 :1.10.9 sipp版本:3.6.1 一.背景描述 sipp是一款VoIP测试工具,日常开发过程中会使用到该软件,但其自身携带的pca ...

  7. centOS 7 添加删除用户和用户组

    1.添加新用户 由于日常使用时root用户权限过大,所以添加一个用户供日常使用,或者供他人使用. 1 新增用户 adduser [用户名] [root@centos ~]# adduser dex 2 ...

  8. 一次查找分子级Bug的经历,过程太酸爽了

    "Debugging is like trying to find a needle in a haystack, except the needle is also made of hay ...

  9. < Python全景系列-9 > Python 装饰器:优雅地增强你的函数和类

    欢迎来到我们的系列博客<Python全景系列>第九篇!在这个系列中,我们将带领你从Python的基础知识开始,一步步深入到高级话题,帮助你掌握这门强大而灵活的编程语法.无论你是编程新手,还 ...

  10. VuePress2.0构建项目文档系统

    VuePress2.0构建项目文档系统 参考TerraMours 官网.https://terramours.site/ 文件结构参考: 1.修改首页README.md 修改项目下的README.md ...