## 字符串函數
* 查看字符的ascii碼值ascii(str),str是空串時返回0
~~~
select ascii('a');
~~~
* 查看ascii碼值對應的字符char(數字)
~~~
select char(97);
~~~
* 拼接字符串concat(str1,str2...)
~~~
select concat(12,34,'ab');
~~~
* 包含字符個數length(str)
~~~
select length('abc');
~~~
* 截取字符串
* left(str,len)返回字符串str的左端len個字符
* right(str,len)返回字符串str的右端len個字符
* substring(str,pos,len)返回字符串str的位置pos起len個字符
~~~
select substring('abc123',2,3);
~~~
* 去除空格
* ltrim(str)返回刪除了左空格的字符串str
* rtrim(str)返回刪除了右空格的字符串str
* trim`([方向 remstr from str)`返回從某側刪除remstr后的字符串str,方向詞包括both、leading、trailing,表示兩側、左、右
~~~
select trim(' bar ');
select trim(leading 'x' FROM 'xxxbarxxx');
select trim(both 'x' FROM 'xxxbarxxx');
select trim(trailing 'x' FROM 'xxxbarxxx');
~~~
* 返回由n個空格字符組成的一個字符串space(n)
~~~
select space(10);
~~~
* 替換字符串replace(str,from_str,to_str)
~~~
select replace('abc123','123','def');
~~~
* 大小寫轉換,函數如下
* lower(str)
* upper(str)
~~~
select lower('aBcD');
~~~
## 數學函數
* 求絕對值abs(n)
~~~
select abs(-32);
~~~
* 求m除以n的余數mod(m,n),同運算符%
~~~
select mod(10,3);
select 10%3;
~~~
* 地板floor(n),表示不大于n的最大整數
~~~
select floor(2.3);
~~~
* 天花板ceiling(n),表示不小于n的最大整數
~~~
select ceiling(2.3);
~~~
* 求四舍五入值round(n,d),n表示原數,d表示小數位置,默認為0
~~~
select round(1.6);
~~~
* 求x的y次冪pow(x,y)
~~~
select pow(2,3);
~~~
* 獲取圓周率PI()
~~~
select PI();
~~~
* 隨機數rand(),值為0-1.0的浮點數
~~~
select rand();
~~~
* 還有其它很多三角函數,使用時可以查詢文檔
## 日期時間函數
* 獲取子值,語法如下
* year(date)返回date的年份(范圍在1000到9999)
* month(date)返回date中的月份數值
* day(date)返回date中的日期數值
* hour(time)返回time的小時數(范圍是0到23)
* minute(time)返回time的分鐘數(范圍是0到59)
* second(time)返回time的秒數(范圍是0到59)
~~~
select year('2016-12-21');
~~~
* 日期計算,使用+-運算符,數字后面的關鍵字為year、month、day、hour、minute、second
~~~
select '2016-12-21'+interval 1 day;
~~~
* 日期格式化date_format(date,format),format參數可用的值如下
* 獲取年%Y,返回4位的整數
* 獲取年%y,返回2位的整數
* 獲取月%m,值為1-12的整數
* 獲取日%d,返回整數
* 獲取時%H,值為0-23的整數
* 獲取時%h,值為1-12的整數
* 獲取分%i,值為0-59的整數
* 獲取秒%s,值為0-59的整數
~~~
select date_format('2016-12-21','%Y %m %d');
~~~
* 當前日期current_date()
~~~
select current_date();
~~~
* 當前時間current_time()
~~~
select current_time();
~~~
* 當前日期時間now()
~~~
select now();
~~~
- mysql
- 1.創建庫和表
- 1.1.數據庫簡介
- 1.2.安裝管理
- 1.3.數據完整性
- 1.4.命令腳本操作
- 2.查詢
- 2.1.條件
- 2.2.聚合
- 2.3.分組
- 2.4.排序
- 2.5.分頁
- 3.高級
- 3.1.關系
- 3.2.連接
- 3.3.自關聯
- 3.4.子查詢
- 3.5.內置函數
- 3.6.視圖
- 3.7.事務
- 4.與python交互
- 4.1.交互類型
- 4.2.增改刪
- 4.3.查詢
- 4.4.封裝
- 4.5.用戶登錄
- Nosql簡介
- mongodb
- 1.基本操作
- 1.1.環境安裝
- 1.2.數據庫操作
- 1.3.集合操作
- 1.4.數據類型
- 1.5.數據操作
- 1.6.數據查詢
- 1.6.1.Limit與Skip
- 1.6.2.投影
- 1.6.3.排序
- 1.6.4.統計個數
- 1.6.5.消除重復
- 2.高級操作
- 2.1.聚合aggregate
- 2.1.1.$group
- 2.1.2.$match
- 2.1.3.$project
- 2.1.4.$sort
- 2.1.5.$limit,$skip
- 2.1.6.$unwind
- 2.2.安全
- 2.3.復制(副本集)
- 2.4.備份和恢復
- 2.5.與python交互
- redis
- 1.基本配置
- 2.數據操作
- 2.1.string
- 2.2.鍵命令
- 2.3.hash
- 2.4.list
- 2.5.set
- 2.6.zset
- 4.高級
- 4.1.發布訂閱
- 4.2.主從配置
- 5.與python交互
- 6.login登陸完善