MySQL相关笔记

MySQL的那些事

学会总结和做笔记也是一件好事
创建数据库:create database 库名;
打开数据库:use 数据库名称;
修改数据库的参数:alter database 数据库名称
default character set 字符集名
default collate 校对规则名;
删除数据库:drop database 数据库名称;
显示已有数据库:show databases;
创建数据表:create table 表名(
->字段名1 数据类型,
->字段名2 数据类型,

-> );
查看数据表结构:1.desc 表名;
2.describe 表名;
3.Show create table;
查看建表语句:show create table 表名\G;
增加列:alter table 表名 add 字段名 数据类型;
1.修改列:alter table 表名 modify 字段名 数据类型;
2.修改列:alter table 表名 change 旧字段名 新字段名 数据类型
删除列:alter table 表名 drop 字段名;
改表更名:alter table 表名 rename 新表名;
删除表:drop table表1,表2,…,表n;
六类约束:
1.not null:非空约束
字段名 数据类型 not null(也可以通过alter table 表名 modify /drop字段名 数据类型来修改约束/删除约束)
2.unique:唯一约束
字段名 数据类型 unique //单字段添加
Constra uk_字段 unique(字段名) //在定义完所有列之后指定约束
3.Primary key:主键约束
字段名 数据类型 primary key //单字段添加主键
constraint pk_字段 primary key(字段)//在定义完所有列之后指定约束
constraint pk_字段 primary key(字段1,…,字段n)
(alter table 表名 drop/add /modify primary key(字段) //删除/添加/修改为主键)
4.Foreign key:外键约束
constraint fk_字段(外键名) foreign key(字段名1…) references 主表名 (主键列1…)//涉及主表与从表概念
alter table 表名 add constraint fk_字段(外键名) foreign key(字段名) references 主表名 (主键列)//drop 删除外键
5.check:检查,指定一个表达式,用于检验指定的数据
6.default:默认约束
like 运算符,用来匹配字符。
“%”匹配任何数目的字符,甚至包括0个字符。
“_”只能匹配一个字符。
“^”匹配以该字符后面的字符开头的字符串
“$”匹配以该字符后面的字符串结尾的字符串
“.”匹配任何一个单字符。
“[…]”匹配在方括号内的字符串。
insert into 表名 (字段名) values (值列表);
insert into 表名1(字段名列表1)
select(字段名列表2) from 表名2 where (条件表达式);将查询结果插入表中//两个必须是’字段个数相同’,数据类型相同。2》》1
update 表名 set 字段名1=新值1,…,字段名n=新值n
where (条件表达式);
delete from 表名 where (某条数据);
all //不去除重复项 distinct //去除重复项
select 字段名 [空格] 别名 或 select 字段名as 别名;
case
where 条件1 then 表达式 1//自定义表达式

else 表达式n
end //替换查询s结果中的数据
select 字段名1,…,字段名n ,计算式 as 别名
from 表名;//计算字段名
数学函数
abs(x) 返回x的绝对值
bin(x) 返回x的二进制(oct返回八进制,hex返回十六进制)
ceiling(x) 返回大于x的最小整数值,取顶
exp(x) 返回值e(自然对数的底)的x次方
floor(x) 返回小于x的最大整数值,取底
greatest(x1,x2,…,xn) 返回集合中最大的值
least(x1,x2,…,xn) 返回集合中最小的值
ln(x) 返回x的自然对数
log(x,y) 返回x的以y为底的对数
mod(x,y) 返回x/y的模(余数)
pi() 返回pi的值(圆周率)
rand() 返回0到1内的随机值,可以通过提供一个参数(种子)使rand()随机数生成器生成一个指定的值。
round(x,y) 返回参数x的四舍五入的有y位小数的值
sign(x) 返回代表数字x的符号的值
sqrt(x) 返回一个数的平方根
truncate(x,y) 返回数字x截短为y位小数的结果

聚合函数(常用于group by从句的select查询中)
avg(col) 返回指定列的平均值,排除为null的值
count(col) 返回指定列中非null值的个数,排除为null的值
min(col) 返回指定列的最小值,排除为null的值
max(col) 返回指定列的最大值,排除为null的值
sum(col) 返回指定列的所有值之和,排除为null的值
group_concat(col) 返回属于一组的列值连接组合而成的结果,排除为null的值

字符串函数
ascii(char) 返回字符的ascii码值
bit_length(str) 返回字符串的比特长度
concat(s1,s2…,sn) 将s1,s2…,sn连接成字符串
concat_ws(sep,s1,s2…,sn) 将s1,s2…,sn连接成字符串,并用sep字符间隔
insert(str,x,y,instr) 将字符串str从第x位置开始,y个字符长的子串替换为字符串instr,返回结果。x从1开始算
find_in_set(str,list) 分析逗号分隔的list列表,如果发现str,返回str在list中的位置
lcase(str)或lower(str) 返回将字符串str中所有字符改变为小写后的结果
ucase(str)或upper(str) 返回将字符串str中所有字符转变为大写后的结果
left(str,x) 返回字符串str中最左边的x个字符
length(s) 返回字符串str中的字符数
ltrim(str) 从字符串str中切掉开头的空格
position(substr,str) 返回子串substr在字符串str中第一次出现的位置
quote(str) 用反斜杠转义str中的单引号
repeat(str, x) 返回字符串str重复x次的结果
reverse(str) 返回颠倒字符串str的结果
right(str,x) 返回字符串str中最右边的x个字符
rtrim(str) 返回字符串str尾部的空格
strcmp(s1,s2) 比较字符串s1和s2,相同返回0,不同返回1
trim(str) 去除字符串首部和尾部的所有空格
日期和时间函数
curdate()或current_date() 返回当前的日期
curtime()或current_time() 返回当前的时间
date_add(date,interval int keyword) 返回日期date加上间隔时间int的结果(int必须按照关键字进行格式化),如:select date_add(current_date,interval 6 month);
date_format(date,fmt) 依照指定的fmt格式格式化日期date值
date_sub(date,interval int keyword) 返回日期date减去间隔时间int的结果(int必须按照关键字进行格式化),如:select date_sub(current_date,interval 6 month);
dayofweek(date) 返回date所代表的一星期中的第几天(1~7)
dayofmonth(date) 返回date是一个月的第几天(1~31)
dayofyear(date) 返回date是一年的第几天(1~366)
dayname(date) 返回date的星期名,英文名,如:select dayname(current_date)
from_unixtime(ts,fmt) 根据指定的fmt格式,格式化unix时间戳ts
hour(time) 返回time的小时值(0~23)
minute(time) 返回time的分钟值(0~59)
month(date) 返回date的月份值(1~12)
monthname(date) 返回date的月份名,英文名,如:select monthname(current_date)
now() 返回当前的日期和时间
quarter(date) 返回date在一年中的季度(1~4),如select quarter(current_date)
week(date) 返回日期date为一年中第几周(0~53)
year(date) 返回日期date的年份(1000~9999)

conv //函数在不同的进制数值中转换
conv(‘字符/数字’,某进制1,某进制2);//某进制1转换为某进制2
一个汉字相当于两个英文字母的宽度

if (1>2,2,3)返回的是3//条件‘1>2’成立的情况执行’2’否则执行‘3’。
ifnull(x,y)//假如x不为null,返回x否则返回y。
in /not in//查询满足指定范围内的条件记录。
order by 字段名/别名 //对查询结果排序[asc:升序|desc:降序]一般来说升序是默认的。
select 查询字段 ‘函数’from 表名 group by 查询字段 having 条件表达式//having子句对分组的数据(最大值,最小值,计数,平均值,和)进行条件筛选。
select 查询字段 from 表名 group by 求和字段 with rollup;//在所有查询出的分组记录之后增加一条记录,记录计算查询出所有记录的总和。
limit 3/-3//前三行/后三行
select 字段 from 表名 limit 3;//格式

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值