⒈常见命令

命令 说明
show databases; 显示数据库列表
use DataBaseName; 打开指定的数据库
show tables; 显示当前打开数据库的表列表
show tables from DataBaseName; 显示指定数据库的表列表
select database(); 显示当前命令指向的数据库
create table TableName(id int,name varchar(50)); 创建表
desc TableName; 查看表结构
show index from TableName 查看表索引
select * from TableName; 查询表数据
insert into TableName(id,name) values(1,'fanqi'),(2,'gaoxing'); 插入数据
SET SQL_SAFE_UPDATES = 0; 禁用MySql安全更新模式
update TableName set name='fanqi' where id = 1; 更新数据
delete from TableName where id = 2; 删除数据
select version(); 查询当前MySql版本

  *如果某些字段名与MySql保留关键字一致,则加上`字段名`着重号即可。

  *MySql有两种通配符

    1.% 代表任意多个字符,包括0个字符

    2._ 代表任意单个字符

  MySql必要时需要使用'\'转义符,也可以使用escape声明特定的转义符

  *is null 和<=>(安全等于)的区别

is null 仅仅可以判断null值,可读性较高,建议使用
<=>

既可以判断null值,也可以判断普通数值,可读性较低

  *排序中,asc代表升序,desc代表降序,默认asc升序。

⒉常见函数

  1.字符串类

命令 说明
select concat('fan','_','qi'); 字符串连接
select ifnull(null,10);

判断是否为空,参数1是判断的表达式或值

参数2是如果为空返回的值

select length('fanqi');

显示长度

*UTF-8编码一个汉字3个字节

*GBK编码一个汉字2个字节

select upper('fanqi');

将参数转化为大写

select lower('FANQI');

将参数转化为小写

select substr('fanqi is very good',6);

select substring('fanqi is very good',6);

功能一样,另一个为简写,截取字符串

*SQL中索引从1开始

select instr('fanqi is very good','fanqi');

返回指定字符第一次出现的索引,如果找不到

则返回0

select trim('a' from 'aaaaaa樊奇aaaaa');

去除字符串中指定字符,如未指定则默认空格

select lpad('fanqi',2,'*');

用指定的字符实现左填充指定长度

*原字符已超出指定长度,则会自动从左截取

select rpad('fanqi',2,'*');

用指定的字符实现右填充指定长度

select replace('fanqi is very good','fanqi','樊奇');

替换指定的字符串

  2.数学函数

select round(1.1923,2);

四舍五入,如果不指定保留的小数位数

则默认只保留整数

select ceil(1.1923); 向上取整,返回>=该参数的最小整数
select floor(1.1923); 向下取整,返回<=该参数的最大整数
select truncate(1.1923,1);

截断,后面有什么都不要了

第二个参数是保留的小数位

select mod(10,3);

取余,mod(a,b)

计算机内部取余公式 a-a/b*b

若a为正,则取余结果为正

若a为负,则取余结果为负

  3.日期函数

select now(); 返回当前系统日期+时间
select curdate(); 返回当前系统日期,不包含时间
select curtime(); 返回当前系统时间,不包含日期

select year(now());
select year('1994-06-24');
select month(now());
select monthname(now());

可以获取日期中指定的部分

年、月、日、时、分、秒

select str_to_date('1994-06-24','%Y-%c-%d');

将字符串通过指定的格式转换成日期

格式符详见下表

select date_format(now(),'%Y年%c月%d日');

将日期通过指定的合适转换成字符串

格式符详见下表

select datediff(now(),'1994-06-24'); 计算两个日期之间相差的天数

        附加:

序号 格式符 含义
1 %Y 4位的年份
2 %y 2位的年份
3 %m 月份(01,02,... 12)
4 %c 月份(1,2,... 12)
5 %d 日(01,02,...)
6 %H 小时(24小时制)
7 %h 小时(12小时制)
8 %i 分钟(00,01,02,... 59)
9 %s 秒(00,01,02,... 59)

  4.其它函数

select version(); 查看当前MySql版本
select database(); 查看当前打开的库
select user(); 查看当前用户
select md5('fanqi'); 返回当前字符串的md5加密形式

  5.流程控制函数

    ①if函数,提供类似于if elst的效果,三目运算符。   

 select if(10<5,'大','小');

    ②case函数,有两种用法

      Ⅰ类似于switch case的效果(既可以当表达式又可以单独出来作为语句)

        语法:

          case 要判断的字段或表达式

          when 常量1 then 要显示的值1或语句1;         //如果为值得话此处不加分号

          when 常量2 then 要显示的值2或语句2;   //

          ........

          else 默认要显示的值n或语句n

          end

        案例:查询员工的工资,要求

                    部门号=30,显示的工资为1.1倍

                    部门号=40,显示的工资为1.2倍

                    部门号=50,显示的工资为1.3倍

                    其它部门,显示的工资为原工资   

 select salary 原始工资,department_id,
case department_id
when 30 then salary * 1.1
when 40 then salary * 1.2
when 50 then salary * 1.3
else salary
end as 新工资
from employees;

        Ⅱ类似于多重if

          语法:

            case

            when 条件1 then 要显示的值1或语句1

            when 条件2 then 要显示的值2或语句2

            .......

            else 默认要显示的值n或语句n

            end

          案例:查询员工的工资情况

              如果工资>20000,显示A级别

              如果工资>15000,显示B级别

              如果工资>10000,显示C级别

              否则,显示D级别

 select salary 原始工资
case
when salary > 20000 then 'A'
when salary > 15000 then 'B'
when salary > 10000 then 'C'
else 'D'
end as 工资级别
from employees;

  6.分组函数

    用于统计使用,又称之为聚合函数或统计函数或组函数

sum 求和
avg 求平均值
max 最大值
min 最小值
count 计算个数

  sum、avg一般用于处理数值型,max、min、count可以处理任何类型

  以上分组函数全部忽略null值,null不参与它们的运算

  可以和distinct搭配实现去重的运算

  select count(字段) from 表名;  //计算非null的行数

  select count(*) from 表名;  //一般用于统计表的行数(带null)

  select count(7) from 表名;  //相当于在表中加了一列常量值,一般用于统计行数

MySql常见命令、函数的更多相关文章

  1. 9、MySQL常见的函数?

    请参考下面的博客文章: MySQL常见的函数

  2. mysql常见命令参数(一)

    1.mysql命令常用参数 1.--auto-rehash (tab键自动补全,表名及表字段) # mysql -u root --auto-rehash # vim my.cnf [mysql] a ...

  3. mysql常见命令

    1.进入mysql:mysql -u root -p 2.允许远程访问: mysql -u root –p mysql>use mysql; mysql>update user set h ...

  4. mysql常见聚合函数

    count():总数量avg():平均数std():标准差sum():求和max():最大值min():最小值 上面的不过多介绍group_concat():分组列值全部展示到一行eg:mysql&g ...

  5. MySQL常见的函数

    一.概述 功能:类似于java中的方法 好处:提高重用性和隐藏实现细节 调用:select 函数名(实参列表); 二.单行函数 1.字符函数 concat:连接 substr:截取子串 upper:变 ...

  6. SEC3 - MySQL常见命令

    1.查看当前所有的数据库 show databases; 2. 打开指定的库名 use 库名称: 3.查看当前库中所有的表 show tables; 4. 查看其他库的所有表 show tables ...

  7. mysql 性能优化常见命令

    mysql 性能优化常见命令: 一: 当发现mysql程序运行缓慢时,在排除sql主机问题之后,可以尝试在schema,table,和sql上进一步进行考查: 1:mysql> show ful ...

  8. MySQL数据库常见命令

    数据库的操作 MySQL服务器的常见命令 开启:sudo service mysql start关闭:sudo service mysql stop重启:sudo service mysql rest ...

  9. mysql常见内置函数

    在mysql中有许多内置的函数,虽然功能都能在PHP代码中实现,但巧妙的应用mysql内置函数可以大大的简化开发过程,提高效率. 在这里我总结一下一些常用的,方便以后查看: mysql字符串函数: c ...

随机推荐

  1. HDU5542 BIT优化dp

    http://acm.hdu.edu.cn/showproblem.php?pid=5542 题意:求严格递增的长度为M的序列的组数. 当dp的优化方案不那么容易一眼看出来的时候,我们可以考虑先写一个 ...

  2. 数据库中in和exists关键字的区别

    数据库中in和exists关键字的区别 in 是把外表和内表作hash join,而exists是对外表作loop,每次loop再对内表进行查询. 一直以来认为exists比in效率高的说法是不准确的 ...

  3. Web API中使用CORS解决跨域

    Web API中使用Cros解决跨域 如果两个页面的协议,端口和域名都相同,则两个页面具有相同的源,注:IE不考虑端口,同源策略不会阻止浏览器发送请求,但是它会阻止应用程序看到响应.如下图所示 COR ...

  4. android 与html交互java调js与js调java操作

    1.首先在项目下建一个assets目录(右击app->New->Folder->Assets Flolder),直接放在项目根目录下和res目录同级别(把所html,js,图片,cs ...

  5. Linux学习笔记:【001】Linux内核分析

    Linux内核 Linux内核是Linux系统构成中最核心的一个部分,是由5个子系统组成. 进程调度: 进程调度(SCHED)控制进程对CPU的访问.当需要选择下一个进程运行时,由调度程序选择最值得运 ...

  6. SQL-数据库刷题

    因是个人总结,只列出对自己有用的或较难的: 下面这道题,第一次拿到,我尝试用 开窗函数 ROW_NUMBER()OVER() 编号,但是发现不能够处理好连续的问题, 上网查找了别人的解法记录下来,其实 ...

  7. vue-router拦截

    说明:以下均在main.js中添加. 主要思路 1.在路由分发时,检查本地缓存是否有账号信息,如果没有,跳转登陆页面,传入当前路由 2.在发送请求时,添加账号token 3.在接收请求时,检查响应的数 ...

  8. FormatMessage

    FormatMessage 获取GetLastError 函数返回的错误代码对应的字符串描述. #include <Windows.h>#include <tchar.h> V ...

  9. WEUI Picker不切换数据

    /*js部分,myPicker是设备号input的ID*/ $('#myPicker').change(function () { /*选择设备号后,根据当前设备号设置不同的摄像头选项,具体判断逻辑根 ...

  10. Immunity Debugger学习

    1.Immunity Debugger简介 Immunity Debugger软件专门用于加速漏洞利用程序的开发,辅助漏洞挖掘以及恶意软件分析.它具备一个完整的图形用户界面,同时还配备了迄今为止最为强 ...