mysql数据库优化课程---14、常用的sql技巧
mysql数据库优化课程---14、常用的sql技巧
一、总结
一句话总结:其实就是sql中那些函数的使用
1、mysql中函数如何使用?
选择字段
其实就是作用域select的选择字段
3.转大写:
ucase();
例子: select id,ucase(username),age from user;
2、sql中的时间戳函数有必要学么?
没必要
其实没必要,因为我们时间都是存的时间戳
所以要是要时间戳对应的日期的话,可以去php中操作
3、重排auto_increment方法?
delete alter
truncate
1.delete
1)delete from user;
2)alter table user auto_increment=1;
2.truncate
truncate user;
4、mysql中命令的帮助?
命令前 ?
1.简单
? create
2.更多
? fun%
5、巧用RAND()提取随机行?
order by rand limit
select * from user order by rand limit 3;
6、mysql中如何使用正则表达式?
regexp 正则表达式
1.以php结尾的数据
select * from user where username regexp 'php$';
2.以php结尾或以linux结尾的数据
select * from user where username regexp 'php$' or username regexp 'linux$';
3.查找包含php或linux或user的数据
select * from user where username regexp 'php|linux|user';
7、mysql中的正则表达式为什么用的少?
like
因为我们一般是从mysql中拿数据,然后扔给php,在php中用正则表达式取数据
正则表达式其实比like慢,一般的操作我们都可以用like实现
二、内容在总结中
1、相关知识
mysql字符串函数:
1.字符串连接
concat();
例子: select concat('php','linux');
2.转小写
lcase();
例子: select lcase('PHP IS VERY MUCH!');
3.转大写:
ucase();
例子: select id,ucase(username),age from user;
4.长度
length();
例子: select length('linux');
5.取除左边的空格
ltrim();
例子: select length(ltrim(' linux'));
6.取除右边的空格
rtrim();
例子: select length(rtrim('linux '));
7.重复
repeat();
例子: select concat(repeat('-',20),'linux');
8.替换
replace();
例子: select replace('linux and java','linux','php');
9.截取
substring();
例子: select substring('/usr/local/src',6,5);
10.空格
space();
例子: select concat('linux',space(20),'php');
mysql数学函数:
1.bin();
十进制转2进制
例子: select bin(10);
2.ceiling();
取上一个整数
例子: select ceiling(10.5);
3.floor();
取下一个整数
例子: select floor(10.5);
4.max();
取最大数
例子: select max(id) from user;
5.min();
取最小数
例子: select min(id) from user;
6.sqrt();
开平方
例子: select sqrt(100);
7.rand();
求随机数
例子: select * from user order by rand();
mysql日期函数:
1.curdate();
当前日期
例子: select curdate();
2.curtime();
当前时间
例子: select curtime();
3.now();
当前日期和时间
例子: select now();
4.unix_timestamp();
当前时间戳
例子: select unix_timestamp();
5.from_unixtime();
时间戳转日期
例子: select from_unixtime(1492176896);
6.week(date);
一年中的第几周
例子: select week('2017-1-8');
7.year(date);
日期中的年部分
例子: select year('2017-4-14');
8.datediff();
日期差值
例子: select datediff('2017-4-14','2017-4-10');
重排auto_increment方法:
1.delete
1)delete from user;
2)alter table user auto_increment=1;
2.truncate
truncate user;
mysql中命令的帮助:
1.简单
? create
2.更多
? fun%
巧用RAND()提取随机行:
select * from user order by rand limit 3;
正则表达式的使用:
1.以php结尾的数据
select * from user where username regexp 'php$';
2.以php结尾或以linux结尾的数据
select * from user where username regexp 'php$' or username regexp 'linux$';
3.查找包含php或linux或user的数据
select * from user where username regexp 'php|linux|user';
最新文章
- Android中的LinearLayout布局
- nginx中相关配置
- [PHP]Yii2框架的坑
- 全面理解HTTP
- 第三百四十一天 how can I 坚持
- Android:启动引导页实现
- 研读代码必须掌握的Eclipse快捷键
- Android 添加子视图(addView和setView)
- 自学SQL语言的例子(使用MySQL实现)
- javascript中对象的不同创建方法
- 再见,CSDN
- 【视频编解码·学习笔记】10. 序列参数集(SPS)介绍
- vue关于数组使用的坑
- Saltstack_使用指南07_远程执行-执行模块
- ip xfrm命令是做什么的?
- hdu-5009 Paint Pearls DP+双向链表 with Map实现去重优化
- windows下python虚拟环境virtualenv安装和使用
- Java并发编程(四)synchronized
- C#程序如何捕捉未try/catch的异常——不弹“XXX已停止工作”报错框
- React Native 组件之TouchableHightLight