MYSQL 一个巧用字符函数巧用字符函数做数据筛选的题
2010-08-01 16:26
453 查看
/*------------------------------
问题描述:
结构:
test 有两个字段,
分别是col1和col2,都是字符字段,
里面的内容都是用,号分隔的三个数字,并且是一一对应的,
比如col1内容是:26,59,6
col2内容是:1502.5,1690,2276.77
一一对应就是26的值是1502.5,59是1690,6对应2276.77
搜索条件:
选择一个id,比如选择59,再输入一个数字,比如:2000
然后就是搜索col1中存在id=59的记录,然后搜索col2小于2000,即1690<2000
举例:
如有以下三条记录,搜索id为59,值小于2000的记录:
26,59,6 | 1502.5,1690,2276.77
59,33,6 | 3502.1,1020,2276.77
22,8,59 | 1332.6,2900,1520.77
搜索到这三个记录存在id为59,之后判断第二个搜索条件应为(即用对应id位置的数字对比):
1690<2000
3502.1>2000
1520.77<2000
*/
/*
+---------+---------------------+
| col1 | col2 |
+---------+---------------------+
| 26,59,6 | 1502.5,1690,2276.77 |
| 22,8,59 | 1332.6,2900,1520.77 |
+---------+---------------------+
*/
问题描述:
结构:
test 有两个字段,
分别是col1和col2,都是字符字段,
里面的内容都是用,号分隔的三个数字,并且是一一对应的,
比如col1内容是:26,59,6
col2内容是:1502.5,1690,2276.77
一一对应就是26的值是1502.5,59是1690,6对应2276.77
搜索条件:
选择一个id,比如选择59,再输入一个数字,比如:2000
然后就是搜索col1中存在id=59的记录,然后搜索col2小于2000,即1690<2000
举例:
如有以下三条记录,搜索id为59,值小于2000的记录:
26,59,6 | 1502.5,1690,2276.77
59,33,6 | 3502.1,1020,2276.77
22,8,59 | 1332.6,2900,1520.77
搜索到这三个记录存在id为59,之后判断第二个搜索条件应为(即用对应id位置的数字对比):
1690<2000
3502.1>2000
1520.77<2000
*/
drop table test; create table test ( col1 varchar(100),col2 varchar(100)); insert test select '26,59,6', '1502.5,1690,2276.77' union all select '59,33,6', '3502.1,1020,2276.77' union all select '22,8,59', '1332.6,2900,1520.77'; select col1,col2 from (select *,find_in_set('59',col1) as rn from test) k where substring_index(concat(',',substring_index(col2,',',rn)),',',-1) <'2000';
/*
+---------+---------------------+
| col1 | col2 |
+---------+---------------------+
| 26,59,6 | 1502.5,1690,2276.77 |
| 22,8,59 | 1332.6,2900,1520.77 |
+---------+---------------------+
*/
相关文章推荐
- MYSQL 一个巧用字符函数做数据筛选的题
- MySQL中使用group_concat()函数数据字符过长报错的问题解决方法
- Visual Studio 2017 - Windows应用程序打包成exe文件(2)- Advanced Installer 关于Newtonsoft.Json,LINQ to JSON的一个小demo mysql循环插入数据、生成随机数及CONCAT函数 .NET记录-获取外网IP以及判断该IP是属于网通还是电信 Guid的生成和数据修整(去除空格和小写字符)
- sqlserver 函数里并返回一个表格数据拼接的字符串
- 如何取得字符点阵数据(GetGlyphOutline函数简单应用)
- php读取文件一个字符的函数fgetc
- MySQL查询在一个表而不在另一个表中的数据
- 取出一个字符串中俩个字符中间的数据.
- MySQL 数据库怎样把一个表的数据插入到另一个表
- c++第九周【任务4】建立一个二维数组类Douary,使该类中有以下数据成员、成员函数及友员函数,完成矩阵的输入、输出、加、减、相等判断等操作。
- 替换mysql数据表中一个字段的部分值
- MySQL数据类型char与varchar中数字代表的究竟是字节数还是字符数?
- JDBC基于MVC架构项目实例-实现对MySQL数据表的增删改查、调用数据表中的存储过程和函数
- 一个通过回车键调另一个数据窗口相关数据到主窗口的函数
- mysql中如何判断 一个数据表是否已经存在
- 【SpamHunter】MySQL之数据相关函数——整理自书籍
- 使用结构体的形式使一个函数返回多个数据
- 写一个函数,检查字符是否是整数,如果是,返回其整数值(最好用四句代码写出)
- 如果字符串的一个子串(其长度大于 1)的各个字符均相同,则称之为等值子串。试设计一算法,求出串S中的最大等值子串 函数返回最大等值子串的长度,如果没有则返回1。 例如: 若S= “abc123abc1
- MySQL 中将一个表的数据插入另外一个表的方法