[摘要]今天在论坛中看到一个关于mysql的问题,问题如下good_id cat_id12654 665,56912655 601,4722goods_id是商品...
今天在论坛中看到一个关于mysql的问题,问题如下
good_id cat_id
12654 665,569
12655 601,4722
goods_id是商品id
cat_id是分类id
当我,怎么根据这种分类ID查数据(一个商品有多个分类,而且用逗号隔开了)
我现在用的是like 这样的话,输入一个分类id是688,或者4722都能出来这个商品,但输入一个722也出来这个商品了。
如果用like做的话,肯定会有问题的,我的开始的想法是,把cat_id里面的字符串换成数组,这样可以利用mysql里面的in操作,这样就不会出现查找722,而4722类别下的产品都跑出来了。我从网上找了半天,这方面的字符串操作函数,没找到,不过我发现了find_in_set这个函数虽然不能,将字符串转换成数组,但是也不会出现上面的情况。我发现自己有好多函数不知道,所以我从手册中,以及网上收集了半天,做了一些例子。
CHAR_LENGTH(str) 返回str的字符数
data:image/s3,"s3://crabby-images/e70c6/e70c6f1be024d8c94800d0a02619904e06cb6649" alt="MySQL中字符串函数的详解"
LENGTH(str) 返回str的字节长度
data:image/s3,"s3://crabby-images/bf234/bf23490cf067a092e87da7de9c50373bd46cd150" alt="MySQL中字符串函数的详解"
CONCAT(str1,str2....) 返回参数str1,str2....的拼接,有一个null值则返回null
data:image/s3,"s3://crabby-images/8569b/8569be35feeabb830d3b7d1485bf30b97d3364ae" alt="MySQL中字符串函数的详解"
CONCAT_WS(x,str1,str2...) ---concat with separator 第一个参数x代表分隔符,后面的参数为字符串
如果x为NULL则返回NULL,如果字符串有NULL会被忽略
data:image/s3,"s3://crabby-images/058b8/058b89020b9fd75f14eba4c36b8d85c3736f290f" alt="MySQL中字符串函数的详解"
INSERT(s1,x,len,s2) 字符串替换 s1 目标字符串 x为s1的开始位置(下标从1开始) len为x之后的长度 s2为需要替换的字符串
如果x超过s1的长度下标,则返回s1,如果len大于x之后剩余字符串长度,则全部替换
data:image/s3,"s3://crabby-images/7df04/7df040ecd059cc5cca35be95a3aaf8566e993ab5" alt="MySQL中字符串函数的详解"
LOWER(str)、LCASE(str) 字符串转为小写
data:image/s3,"s3://crabby-images/0e9b7/0e9b7a8c209a1875a81cbbce9e3e3f07c65ed44f" alt="MySQL中字符串函数的详解"
UPPER(str)、UCASE(str) 字符串转为大写
data:image/s3,"s3://crabby-images/f03eb/f03eb665f189e8106280d9ee095009eeaf637a13" alt="MySQL中字符串函数的详解"
LEFT(str,n) 返回字符串str最左边的n个字符
data:image/s3,"s3://crabby-images/301ec/301ec8fb477c763e02e06c6c69c821d9136d0e9d" alt="MySQL中字符串函数的详解"
RIGHT(str,n) 返回字符串str最右边的n个字符
data:image/s3,"s3://crabby-images/777a4/777a43f67c8273e8a4f88689b1783a7c78fd1ad5" alt="MySQL中字符串函数的详解"
LPAD(s1,len,s2) 返回s2从s1的左边填充直到总长度为len,如果len<s1的长度,则s2不填充,返回s1从左开始的len长度字符
data:image/s3,"s3://crabby-images/c6744/c67442a63d66243002f8c4cc1c4871a0ad259442" alt="MySQL中字符串函数的详解"
RPAD(s1,len,s2) 返回s2从s1的右边填充直至len的长度,如果len<s1的长度,则s2不填充,返回s1从左开始的len长度字符
data:image/s3,"s3://crabby-images/dd013/dd013966f57290a05fcfe3d64372625c4c07d2ed" alt="MySQL中字符串函数的详解"
LTRIM(S) 删除左侧的空格 RTRIM(s) 删除右侧的空格 TRIM(s) 删除两侧的空格
data:image/s3,"s3://crabby-images/7cf64/7cf64832d28e4994566f810eacbfb578b9527b44" alt="MySQL中字符串函数的详解"
TRIM(s1 FROM s2) 删除s2两端出现的s1字符串
data:image/s3,"s3://crabby-images/0fd92/0fd927619d41200b9e564cb972721c4c92a9c9e5" alt="MySQL中字符串函数的详解"
REPEAT(s,n) 返回n个s组成的字符串,n<=0,返回空;s或者n为NULL,返回NULL
data:image/s3,"s3://crabby-images/ebd3b/ebd3b4586ae35ceb6470d5f2a98ee15ce4f9be0d" alt="MySQL中字符串函数的详解"
SPACE(n) 返回n个空格字符串
data:image/s3,"s3://crabby-images/368a8/368a819294eb9870af6bc982101eb7a9f447ffd8" alt="MySQL中字符串函数的详解"
REPLACE(s,s1,s2) 返回--由s2替换s中的所有s1字符串的结果
data:image/s3,"s3://crabby-images/6e877/6e877d5a018d63f321d81cab79feea939a3e6eed" alt="MySQL中字符串函数的详解"
STRCPM(s1,s2) s1==s2 返回0 s1<s2 返回-1 s1>s2 返回1
data:image/s3,"s3://crabby-images/e7fef/e7fef8dc44e3ffa351f9cf1fd93709a46cac87e5" alt="MySQL中字符串函数的详解"
SUBSTRING(s,n,len) 、MID(s,n,len)返回s从n开始的len长度的字符串 ,若n<0,则从s的最后倒数n个开始截取,n=0的话返回空字符串;len可以省略-截取n之后的所有字符
data:image/s3,"s3://crabby-images/6ed50/6ed50a2c6ee389a7b73bcf8ca48ec2c61593bfca" alt="MySQL中字符串函数的详解"
data:image/s3,"s3://crabby-images/4fbde/4fbded0b749aab89357b4ea5438760b6b576cc35" alt="MySQL中字符串函数的详解"
LOCATE(str1,str2)、POSITION(str1 IN str2)、INSTR(str2,str1) 返回str1在str2中出现的开始位置
data:image/s3,"s3://crabby-images/13443/13443ec0d3a673ecd0821636cf1dcceffbb88181" alt="MySQL中字符串函数的详解"
REVERSE(s) 返回s的字符串的反转
data:image/s3,"s3://crabby-images/1c7c9/1c7c9b382f067b68bfd260855ca9736ff5df9b19" alt="MySQL中字符串函数的详解"
ELT(n,str1,str2,str3...) 返回str1,str2.. 中的第n个字符串 ,n超出返回返回null
data:image/s3,"s3://crabby-images/a0b67/a0b67de39d6965e716d1929c1f27140dcb2e9f6c" alt="MySQL中字符串函数的详解"
FIELD(s,str1,str2,str3....) 返回s在str1,str2.....中的第一次出现的位置,没有返回0
data:image/s3,"s3://crabby-images/54c4d/54c4d2030e0b50e11dfc86789b4b73953cf04af5" alt="MySQL中字符串函数的详解"
FIND_IN_SET(s,str1) 返回s在str1中的出现的位置,其中str1由多个字符串组成,逗号隔开的列表
data:image/s3,"s3://crabby-images/6437a/6437aa8431700562cc60b368f9532bf9922655cb" alt="MySQL中字符串函数的详解"
以上就是MySQL中字符串函数的详解的详细内容,更多请关注php中文网其它相关文章!
微信
分享
学习教程快速掌握从入门到精通的SQL知识。
关键词:MySQL中字符串函数的详细说明