-- 常用函数 字符编码uft8汉字为3个字节 gbk汉字两个字节 gbk占用空间小速度快 utf8兼容性好

-- length 返回字符的字节数
SELECT LENGTH('asd王');
-- char_length 返回字符个数
SELECT CHAR_LENGTH('asf喊');

SELECT * FROM student WHERE CHAR_LENGTH(sname)=2;

SELECT * FROM student WHERE sname LIKE '__';

SELECT RAND();-- 返回随机小数[0,1)

SELECT ROUND(RAND()); -- 0或1
SELECT ROUND(RAND()*3)+1;-- 1到4之间的随机整数 rand()*3的范围是0-3

SELECT * FROM student LIMIT 2 ;-- 限制显示两行

SELECT * FROM student ORDER BY RAND() LIMIT 2;-- 随机查询两条记录

-- 查看十天的会员注册人数
-- menber 会员表 regdate 注册日期
SELECT COUNT(*) FROM menber WHERE regdate BETWEEN DATE_ADD(NOW(),INTERVAL -10 DAY);
-- 查看十天前的时间日期
SELECT DATE_ADD(NOW(),INTERVAL -10 DAY),NOW();
-- 十天后的时间
SELECT DATE_ADD(NOW(),INTERVAL 10 DAY),NOW();

SELECT DATE_ADD(NOW(),INTERVAL -2 HOUR);-- 两小时之前

SELECT DATE_ADD(NOW(),INTERVAL -8 MONTH) 八个月前;

-- datefiff 两个日期差的天数
SELECT DATEDIFF(CURDATE(),'1992-9-18');

-- 格式化日期函数 例:y只显示16年 Y显示2016年
SELECT DATE_FORMAT(NOW(),'%Y年%m月%d日');

CREATE TABLE ss(
sid INT,
sname VARCHAR(30),
sscore TINYINT UNSIGNED,
sbirthday DATETIME
);
DELETE FROM ss;
INSERT INTO ss VALUES(1,'张三',80,'1992-9-18 9:50:22'),(2,'李四',50,'1996-4-18'),(1,'王五',90,'1988-6-22');

SELECT * FROM ss;

SELECT sname 姓名,DATE_FORMAT(sbirthday,'%Y年%m月') 出生年月 FROM ss;

-- TIMESTAMPDIFF可算年月日时分秒 具体看DATE_ADD
SELECT TIMESTAMPDIFF(HOUR,'2015-7-10 12:30:00',NOW()) 工作时间;-- 从那个时间点到现在是多少个小时

SELECT TIMESTAMPDIFF(MINUTE,'2015-7-10 12:30:00',NOW()) 工作时间; -- 总的分钟数

SELECT TIMESTAMPDIFF(MONTH,'2015-7-10 12:30:00',NOW()) 工作时间;
----------------------------
SELECT WEEKOFYEAR(NOW());-- 当前是今年的第几周

-- 日期时间 存储过程可以使用int unsigned类
-- form_unixtime 将数字表达的日期格式化成标准yyyy-mm-dd h-i-s
SELECT FROM_UNIXTIME(1476555100,'%Y-%m-%d %T');

SELECT FROM_UNIXTIME(UNIX_TIMESTAMP()),UNIX_TIMESTAMP();-- 日期对应的数字

SELECT UNIX_TIMESTAMP();-- 将日期转换成数字存储

SELECT INET_ATON ('111.13.100.91');-- 将IP转换成相应的数字 1863148635

--------------------------------------
-- 字符串处理
-- 大小写转换
SELECT UPPER('hello'),LOWER('HELLO');

-- 不区分大小写Admin
SELECT * FROM admin WHERE LOWER(sname)=LOWER('admin');

SELECT LEFT(sname,2)FROM ss;-- 取目标的左边(右边用right)前2个字符

SELECT MID(sname,2,1)FROM ss;-- 从第二个字开始取一个字符

UPDATE menber SET PASSWORD=RIGHT(tel,6) WHERE mmid=1000;-- 将id为1000的会员的密码设置成他手机号的后六位

SELECT IFNULL(NULL,'保密');
SELECT IFNULL('男','保密');
SELECT IFNULL('女','保密');

SELECT IFNULL(sgender,'保密')FROM student;

SELECT * FROM ss;
UPDATE ss SET sscore=20 WHERE sid=2;

SELECT sid,sname,sscore,IF(sscore>=90,'优秀',IF(sscore>=70,'良好',IF(sscore>=60,'及格','补考'))) 等级 FROM ss;

------------------------------------

-- 加密函数

-- md5 32位 sha1 40位 都是单项加密
SELECT MD5('admin'),SHA1('admin'),PASSWORD('aaa');

-- uuid 36位16进制的全球唯一字符串
SELECT UUID(),LENGTH(UUID());-- 84da3ed7-e74c-11e5-8edb-089e0156af5a

SELECT FORMAT(2,2);-- 2.00 指定两位小数

-- 数字转IP IP转数字(最好整型无符号)
SELECT INET_ATON('192.168.1.1');-- 3232235777

SELECT INET_NTOA('3232235777');-- 192.168.1.1

-- php+mysql 项目开发的时间

日期时间和IP地址采用数据库的 INT UNSIGNED 类型存储

reg DATETIME
reg INT UNSIGNED

Mysql-学习笔记(==》常用函数 八)的更多相关文章

  1. MySql学习笔记——存储函数

    在学习完存储过程后,今天主要回顾一下mysql中的存储函数的知识. 函数与存储过程的区别 首先,存储函数也是过程式对象之一,与存储过程相似.它们都是由SQL和过程式语句组成的代码片断,并且可以从应用程 ...

  2. Oracle学习笔记——常用函数总结

    在平时写PL/SQL的时候,经常要用到很多系统自带的函数,而这些函数用起来非常好用,但是每次用完以后,就又忘到脑后了,为了加深自己的映象,以及对这些函数做一个全面的总结,就有了今天这篇文章. 首先这就 ...

  3. mysql学习笔记—常用sql函数

    SQL 拥有很多可用于计数和计算的内建函数. SQL Aggregate 函数 SQL Aggregate 函数计算从列中取得的值,返回一个单一的值. 有用的 Aggregate 函数: AVG() ...

  4. MYSQL学习笔记——常用语句

    1.检索数据 1.1.检索单个列:SELECT prod_name FROM products; 1.2.检索多个列:SELECT prod_id, prod_name, prod_price FRO ...

  5. Oracle学习笔记—常用函数

    这里记录一些oracle常用的函数. TO_NUMBER()函数 将字符串类型转换成一个 number 类型的值. SELECT TO_NUMBER('100.00') FROM DUAL; TO_C ...

  6. mysql学习笔记--- 字符串函数、日期时间函数

    一.常见字符串函数: 1.CHAR_LENGTH  获取长度(字符为单位) 2.FORMAT  格式化 3.INSERT  替换的方式插入 4.INSTR  获取位置 5.LEFT/RIGHT  取左 ...

  7. mysql学习笔记—常用sql语句

    sql注意事项: SQL 对大小写不敏感:SELECT 与 select 是相同的 某些数据库系统要求在每条 SQL 语句的末端使用分号. CREATE DATABASE CREATE DATABAS ...

  8. MySql学习笔记(一)之DQL常用查询

    MySql学习笔记(一)之DQL常用查询 前言:mysql是中小型的数据库软件,SQL语言分为DDL,DCL,DML,DQL四种,在这里重点讲解DQL的单表查询. 正文:在学习mysql单表查询之前, ...

  9. MYSQL学习笔记三:日期和时间函数

    MYSQL学习笔记三:日期和时间函数 1. 获取当前日期的函数和获取当前时间的函数 /*获取当前日期的函数和获取当前时间的函数.将日期以'YYYY-MM-DD'或者'YYYYMMDD'格式返回 */ ...

  10. MySQL学习笔记一

    MySQL 学习笔记 一 一.数据库简单介绍 1. 按照数据库的发展时间顺序,主要出现了以下类型数据库系统: Ø 网状型数据库 Ø 层次型数据库 Ø 关系型数据库 Ø 面向对象数据库 上面4中数据库系 ...

随机推荐

  1. 记录把方法添加到 JavaScript 对象不明白的地方

    <!DOCTYPE html> <html> <body> <script> function person(firstname,lastname,ag ...

  2. XML节点名称中有小数点处理(deal with dot)导致使用xpath时报错解决方法

    <?xml version="1.0"?> <ModifyFiles> <_Layout.cshtml>123456</_Layout.c ...

  3. C++之路进阶——边表

    边表:利用边的关系来表示一个图. 用到数组: head//head[i]表示从i点出发的第一条边的编号; next[i]//与第i条边起点相同的下一条边的编号; a[i]//第i条边的终点; val[ ...

  4. demo03linearlayoutdemo;

    package com.example.demo03linearlayoutdemo; import android.os.Bundle; import android.app.Activity; i ...

  5. oracle的散列聚簇表

    在簇表中,Oracle使用存储在索引中的键值来定位表中的行, 而在散列聚簇表中,使用了散列函数代替了簇索引,先通过内部函数或者自定义的函数进行散列计算,然后再将计算得到的码值用于定位表中的行. 创建散 ...

  6. LDA-math-LDA 文本建模

    http://cos.name/2013/03/lda-math-lda-text-modeling/ 5. LDA 文本建模 5.1 游戏规则 对于上述的 PLSA 模型,贝叶斯学派显然是有意见的, ...

  7. [Ubuntu] Ubuntu搭建VPN服务器pptpd

    在 Ubuntu 上搭建 VPN 服务器的方法非常多,比较著名的有 PPTP, L2TP/IPSec 和 OpenVPN. 这三种方式中后两者的安全性比较好,但配置较麻烦.其中 OpenVPN 在 W ...

  8. win7 IIS发布项目遇到的问题

     问题一: HTTP 错误 404.3 – Not Found 由于扩展配置问题而无法提供您请求的页面.如果该页面是脚本,请添加处理程序.如果应下载文件,请添加 MIME 映射. 1.依次打开控制面板 ...

  9. Portal Page的呈現

    先看一下在JSR168中提到的Portal page,可以了解一個Portal Page上大概有哪些element: OK...進入本次主題 PSML:PSML的全名是Portal Structure ...

  10. 创建数据库和表的SQL语句【转】

    创建数据库和表的SQL语句 转至http://www.cnblogs.com/philanthr/archive/2011/08/09/2132398.html 创建数据库的SQL语句: 1 crea ...