MySQL练习之3:MySQL函数的使用

案例:使用各种函数操作数据,掌握各种函数的作用和使用方法。
(1)使用数学函数rand()生成3个10以内的随机整数。
(2)使用sin(),con(),tan(),cot()函数计算三角函数值,并将计算结果转换成整数值。
(3)创建表,并使用字符串和日期函数对字段值进行操作。
(4)使用case进行条件判断,如果m_birth小于2000年,就显示"old";如果m_birth大于2000年,则显示"young"。
(免费学习推荐:mysql视频教程)
(1)、使用数学函数rand()生成3个10以内的随机整数。
mysql> select round( rand() * 10 ),round( rand() * 10 ), round( rand() * 10 );+----------------------+----------------------+----------------------+| round( rand() * 10 ) | round( rand() * 10 ) | round( rand() * 10 ) |+----------------------+----------------------+----------------------+| 9 | 8 | 1 |+----------------------+----------------------+----------------------+1 row in set (0.00 sec)
(2)、使用sin(),con(),tan(),cot()函数计算三角函数值,并将计算结果转换成整数值。
mysql> select pi(), -> sin(pi()/2), -> cos(pi()), -> round(tan(pi()/4)), -> floor(cot(pi()/4));+----------+-------------+-----------+--------------------+--------------------+| pi() | sin(pi()/2) | cos(pi()) | round(tan(pi()/4)) | floor(cot(pi()/4)) |+----------+-------------+-----------+--------------------+--------------------+| 3.141593 | 1 | -1 | 1 | 1 |+----------+-------------+-----------+--------------------+--------------------+1 row in set (0.00 sec)
(3)、创建表,并使用字符串和日期函数对字段值进行操作。
①创建表member,其中包含5个字段,分别为auto_increment约束的m_id字段、varchar类型的m_FN字段、varchar类型的m_LN字段、datetime类型m_birth字段和varchar类型的m_info字段。
mysql> create table member -> ( -> m_id int auto_increment primary key, -> m_FN varchar(100), -> m_LN varchar(100), -> m_birth datetime, -> m_info varchar(255) null -> );Query OK, 0 rows affected (0.21 sec)
②插入一条记录,m_id值为默认,m_FN值为"Halen",m_LN值为"Park",m_birth值为1970-06-29,m-info值为"GoodMan"。
mysql> insert into member values -> ( null,'Halen','Park','1970-06-29','GoodMan');Query OK, 1 row affected (0.01 sec)mysql> select * from member;+------+-------+------+---------------------+---------+| m_id | m_FN | m_LN | m_birth | m_info |+------+-------+------+---------------------+---------+| 1 | Halen | Park | 1970-06-29 00:00:00 | GoodMan |+------+-------+------+---------------------+---------+1 row in set (0.00 sec)
③返回m_FN的长度,返回第一条记录中人的全名,将m_info字段值转换成小写字母。将m_info的值反向输出。
mysql> select length(m_FN),concat(m_FN,m_LN), -> lower(m_info),reverse(m_info) from member;+--------------+-------------------+---------------+-----------------+| length(m_FN) | concat(m_FN,m_LN) | lower(m_info) | reverse(m_info) |+--------------+-------------------+---------------+-----------------+| 5 | HalenPark | goodman | naMdooG |+--------------+-------------------+---------------+-----------------+1 row in set (0.00 sec)
④计算第1条记录中人的年龄,并计算m_birth字段中的值在那一年中的位置,按照"Saturday 4th October 1997"格式输出时间值。
mysql> select year(curdate())-year(m_birth) as age,dayofyear(m_birth) as days, -> date_format(m_birth,'%W %D %M %Y') as birthDate from member;+------+------+-----------------------+| age | days | birthDate |+------+------+-----------------------+| 49 | 180 | Monday 29th June 1970 |+------+------+-----------------------+1 row in set (0.00 sec)
⑤插入一条新的记录,m_FN值为"Samuel",m_LN值为"Greem",m_birth值为系统当前时间,m_info为空。使用last_insert_id查看最后插入的id值。
mysql> insert into member values( null,'Samuel','Green',now(),null);Query OK, 1 row affected (0.04 sec)mysql> select * from member;+------+--------+-------+---------------------+---------+| m_id | m_FN | m_LN | m_birth | m_info |+------+--------+-------+---------------------+---------+| 1 | Halen | Park | 1970-06-29 00:00:00 | GoodMan || 2 | Samuel | Green | 2019-08-20 12:43:23 | NULL |+------+--------+-------+---------------------+---------+3 rows in set (0.00 sec)
可以看到表中有两条记录,接下来使用last_insert_id()函数查看最后插入的id值,SQL语句如下:
mysql> select last_insert_id();+------------------+| last_insert_id() |+------------------+| 3 |+------------------+1 row in set (0.00 sec)
(4)、使用case进行条件判断,如果m_birth小于2000年,就显示"old";如果m_birth大于2000年,则显示"young"。
mysql> select m_birth,case when year(m_birth)<2000 then 'old'
-> when year(m_birth)>2000 then 'young'
-> else 'not born' end as status from member;+---------------------+--------+| m_birth | status |+---------------------+--------+| 1970-06-29 00:00:00 | old || 2019-08-20 12:43:23 | young |+---------------------+--------+3 rows in set (0.00 sec)
相关免费学习推荐:mysql数据库(视频)
以上是MySQL练习之3:MySQL函数的使用的详细内容。更多信息请关注PHP中文网其他相关文章!
热AI工具
Undress AI Tool
免费脱衣服图片
Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片
AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。
Clothoff.io
AI脱衣机
Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!
热门文章
热工具
记事本++7.3.1
好用且免费的代码编辑器
SublimeText3汉化版
中文版,非常好用
禅工作室 13.0.1
功能强大的PHP集成开发环境
Dreamweaver CS6
视觉化网页开发工具
SublimeText3 Mac版
神级代码编辑软件(SublimeText3)
建立与MySQL Server的安全远程连接
Jul 04, 2025 am 01:44 AM
TosecurelyConnectToaremoteMysqlServer,Usesshtunneling,configuremysqlforremoteaccess,setFireWallrules,andConsidersSlencryption 。首先,stardansshtunnelwithssh-l3307:localhost:3306user@remote-Server-server-nandConnectViamySql-h127.0.0.0.0.1-p3307.second,editmys
MySQL中的交易隔离级别是多少?默认值是哪个?
Jun 23, 2025 pm 03:05 PM
MySQL的默认事务隔离级别是可重复读(RepeatableRead),它通过MVCC和间隙锁防止脏读和不可重复读,并在大多数情况下避免幻读;其他主要级别包括读未提交(ReadUncommitted),允许脏读但性能最快,1.读已提交(ReadCommitted)确保读取已提交数据但可能遇到不可重复读和幻读,2.可重复读(RepeatableRead)默认级别,保证事务内多次读取结果一致,3.串行化(Serializable)最高级别,通过锁阻止其他事务修改数据,确保数据完整性但牺牲性能;可通过
如何将MySQL bin目录添加到系统路径
Jul 01, 2025 am 01:39 AM
要将MySQL的bin目录添加到系统PATH,需根据不同操作系统进行配置。1.Windows系统:找到MySQL安装目录下的bin文件夹(默认路径通常为C:\ProgramFiles\MySQL\MySQLServerX.X\bin),右键“此电脑”→“属性”→“高级系统设置”→“环境变量”,在“系统变量”中选中Path并编辑,新增MySQLbin路径,保存后重启命令提示符并输入mysql--version验证;2.macOS和Linux系统:Bash用户编辑~/.bashrc或~/.bash_
MySQL WorkBench在哪里保存连接信息
Jun 26, 2025 am 05:23 AM
MySQLWorkbench将连接信息存储在系统的配置文件中,具体路径因操作系统而异:1.Windows系统中位于%APPDATA%\MySQL\Workbench\connections.xml;2.macOS系统中位于~/Library/ApplicationSupport/MySQL/Workbench/connections.xml;3.Linux系统中通常位于~/.mysql/workbench/connections.xml或~/.local/share/data/MySQL/Wor
使用mySQL中的mysqldump执行逻辑备份
Jul 06, 2025 am 02:55 AM
mysqldump是用于执行MySQL数据库逻辑备份的常用工具,它生成包含CREATE和INSERT语句的SQL文件以重建数据库。1.它不备份原始文件,而是将数据库结构和内容转换为可移植的SQL命令;2.适用于小型数据库或选择性恢复,不适合TB级数据快速恢复;3.常用选项包括--single-transaction、--databases、--all-databases、--routines等;4.恢复时使用mysql命令导入,并可关闭外键检查以提升速度;5.建议定期测试备份、使用压缩、自动化调
分析MySQL缓慢查询日志以查找性能瓶颈
Jul 04, 2025 am 02:46 AM
开启MySQL慢查询日志并分析可定位性能问题。 1.编辑配置文件或动态设置slow_query_log和long_query_time;2.日志包含Query_time、Lock_time、Rows_examined等关键字段,辅助判断效率瓶颈;3.使用mysqldumpslow或pt-query-digest工具高效分析日志;4.优化建议包括添加索引、避免SELECT*、拆分复杂查询等。例如为user_id加索引能显着减少扫描行数,提升查询效率。
在MySQL列和查询中处理零值
Jul 05, 2025 am 02:46 AM
处理MySQL中的NULL值需注意:1.设计表时关键字段设为NOTNULL,可选字段允许NULL;2.查询判断必须用ISNULL或ISNOTNULL,不能用=或!=;3.可用IFNULL或COALESCE函数替换显示默认值;4.插入或更新时直接使用NULL值需谨慎,注意数据源和ORM框架处理方式。NULL表示未知值,不等于任何值,包括自身,因此查询、统计、连接表时要特别小心,避免漏数据或逻辑错误。合理使用函数和约束可以有效减少因NULL带来的干扰。
重置MySQL Server的root密码
Jul 03, 2025 am 02:32 AM
要重置MySQL的root密码,请按以下步骤操作:1.停止MySQL服务器,使用sudosystemctlstopmysql或sudosystemctlstopmysqld;2.以--skip-grant-tables模式启动MySQL,执行sudomysqld--skip-grant-tables&;3.登录MySQL并根据版本执行相应的SQL命令修改密码,如FLUSHPRIVILEGES;ALTERUSER'root'@'localhost'IDENTIFIEDBY'your_new


