第一种: mysql自带语法CONCAT(string1,string2,…),此处是直接把string1和string2等等的字符串拼接起来(无缝拼接哦) 说明:此方法在拼接的时候如果有一个值为NULL...SELECT CONCAT(“name=”,”lich”) AS test; 第二种: 第二种也是mysql自带语法CONCAT_WS(separator,string1,string2,…),但是可以多个字符串用指定的字符串进行拼接...(带缝拼接哦) 说明:string1,string2代表的是字符串,而separator代表的是连接其他参数的分隔符,可以是符号,也可以是字符串。...NULL,’name=’,’lich’,null) AS test; 3. select concat_ws(“hello,”,’name=’,’lich’,null) AS test; 第三种: 也是mysql
,也就是乱码字符。毫无疑问,这定然是mysql字符集的配置问题。找到了解决问题的方向,那么,自然就很好办了。...解决问题 我的问题是出现在ubntu上的,如果你是windows用户,那么直接去安装mysql的根目录找配置文件就好了,修改方式和ubuntu上的是一样的。我接下来就会说明。...首先,进入到ubuntu的安装目录 cd /etc/mysql/ 如果你安装的是5.7的版本,我的就是5.7的,那么继续使用cd命令进入这个文件夹 cd mysql.conf.d 进去之后就会发现,这个其实是...mysql的各种配置文件所在的文件夹,现在你可以在百度上搜索到的mysql字符集解决办法好像都有点落后了,因为配置文件在无声无息的发生了位置改变。...结语 以上就是mysql的乱码配置过程,也可以是字符集配置过程,utf8这种编码格式是适用于所有的字符的,所以一般我们配置都是用的这种编码。
不同编码,字符集合不完全一样,存在某字符集的字符无法映射到另外一个字符集。 比如gbk编码中的中文字符,转成latin-1编码时,就找不到对应的二进制编码。...MySQL做字符集转换的时候,gbk中文字符->latin-1,很多就转成'?'号(0x3f),这种大集合转成小集合,基本是不可逆的。...MySQL执行过程 对一个 MySQL 的执行过程,字符集转换,一般涉及到一下三个步骤: 收到请求,将请求数据从 character_set_client ->character_set_connection...Character_set_client告诉MySQL Server,传入的是一个 gbk 编码的,'中'这个输入,当作了0xD6 D0传入。...其实很简单,表创建的字符集和set names都设置成同一个字符集,就基本可以满足输入数据不会在转换过程中失真,也就是说输入是什么,输出就是什么。建议有中文的都设置成utf8字符集,一劳永逸。
LEFT(rull,LOCATE(‘ml’,rull)-1) where rull like ‘%ml%’ ; substring_index(str,delim,count),str是要截取的字符串
mysql支持中文汉字排序的实现方法 在查询的时候,经常用到排序,英文的排序自然好说,但是在线上特定场景环境中,可能需要对中文进行排序,比如用户的姓名、地址等等。在mysql中如何对中文排序呢?...我们可以使用ORDER BY CONVERT(列名 USING 字符编码集)函数即可将中文列名按拼音顺序进行排序。...GENDER 1 廖XX 27 F 2 周XX 16 M 3 白XX 36 M 4 安XX 20 F 使用CONVERT函数,在查询的时候使用指定字符集编码如...可以按照汉字拼音声母排序,SQL: /*SQL*/ SELECT USER_NAME FROM `student` ORDER BY CONVERT(USER_NAME USING gbk); /*查询结果
CONCAT 将多个结果作为字符串拼接在一起 concat(str1,str2,...)...实例: select concat(o.user_name,o.user_number) from user o where user_id = '1' 但是如果查询过程中有一个字符串为 null 则整个结果都将是...o where user_id = '1' 这种情况下,结果中有 null 的话,也不会返回 null ,但是如果将分隔符指定为 null 则结果会全变成 null GROUP_CONCAT 将多行的字符串分组整合成一个字符串...student o group by o.class_id 上面这个 sql 是将学生按班级进行分组,然后将学生的姓名拼装到一起 更复杂一些的例子,可以将学生的名字、学生的学科和分数进行分组查询并拼接结果
要查询以某个字符开头的数据,在Mysql中常常用到。...常用的语句有: 下面以查询文章标题以“正”字开头的语句为例: 使用通配符: SELECT * FROM `article` where title like '正%'; 使用left函数: SELECT...* FROM `article` where left(title,1)='正'; 使用字符串截取函数: SELECT * FROM `article` where substring(title,1,1...where `name` not REGEXP '^[0-9]' 以字母开头 select * from mot_terms where `name` REGEXP '^[a-zA-Z]' 已知数字和特殊字符开头...select * from mot_terms where `name` REGEXP '^[@#$%&0-9]' 参考:http://www.deardai.com/mysql/idbt94.html
原文出处: 温国兵 一 引子 在生产环境中,经常会有这样的场景:获得中文数据。那问题就来了,怎么才能匹配出中文字符呢? 本文提供两种方法。...> SELECT name, -> CASE name REGEXP "[u0391-uFFE5]" -> WHEN 1 THEN "不是中文字符" ->...ELSE "是中文字符" -> END AS "判断是否是中文字符" -> FROM user; +-----------+-----------------------------+ |...name | 判断是否是中文字符 | +-----------+-----------------------------+ | robin | 不是中文字符 | | 温国兵...| 是中文字符 | +-----------+-----------------------------+ 2 rows in set (0.00 sec) mysql> SELECT
Mysql字符串截取 和 截取字符进行查询 一、MySQL中字符串的截取 MySQL中有专门的字符串截取函数:其中常用的有两种:substring_index(str,delim,count) 和concat...函数括号里面的依次为:要分隔截取的字符串(如:”aaa_bbb_ccc”)、分隔符(如:“_”)、位置(表示第几个分隔符处,如:“1”)。...例子:concat(‘m’,’y’,’s’,’q’,’l’); 返回:mysql 二、依据表中的某个字段查询包含有这个字符的所有数据 1.find_in_set:SELECT * FROM...user WHERE find_in_set(‘吴’,name); 查询user表中所有name包含“吴”的数据 2.REGEXP:SELECT * FROM user WHERE name...REGEXP ‘(‘吴’|‘刘’)’; 使用正则,查询包含刘或者吴的数据 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。
MySQL联合查询 联合查询:union,将多次查询(多条select语句)的结果,在字段数相同的情况下,在记录的层次上进行拼接。...执行如下 SQL 语句,进行测试: — 联合查询,默认去重 select * from class union distinct select * from class; — 联合查询,保留所有记录 select...特别地,联合查询只要求字段数相同,而跟类型无关。...意义 联合查询的意义有两种,分别为: 查询同一张表,按时需要不同,例如查询学生信息,要求男生按年龄升序排序,女生按年龄降序排序; 多表查询,多张表的结构是完全一样的,保持的数据结构也是一样的。...根据我们刚刚学到的联合查询,貌似很容易啊!
慢查询日志概念 MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录在MySQL中响应时间超过阀值的语句,具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询日志中...默认情况下,Mysql数据库并不启动慢查询日志,需要我们手动来设置这个参数,当然,如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会或多或少带来一定的性能影响。...log-slow-queries :旧版(5.6以下版本)MySQL数据库慢查询日志存储路径。...开启了慢查询日志只对当前数据库生效,如果MySQL重启后则会失效。.../mysql/mysql06_slow.log 得到按照时间排序的前10条里面含有左连接的查询语句。
= 不相等 > 大于 >= 大于等于 < 小于 <= 小于等于 BETWEEN 位于两个数值之间 查询价格小于10.2的水果 mysql> SELECT f_name,f_price FROM fruits...查询指定范围内的条件记录,将所有的查询条件用括号括起来。...apple | 5.20 | | cherry | 3.20 | +-----------+---------+ 8 rows in set (0.00 sec) 带LIKE的字符串匹配查询...LIKE查询一起使用的通配符有‘%'和‘',其中(下划线)只能一次值匹配一个字符 %(百分号)可以匹配任意多字符。...此时外层语句不做任何查询。
:索引没有设计好、SQL 语句没写好、MySQL 选错了索引 ’mysql慢查询优化 第一步:开启mysql慢查询日志,通过慢查询日志定位到执行较慢的SQL语句。...存储过程的信息对查询的影响情况 EXPLAIN 不考虑各种 Cache EXPLAIN 不能显示 MySQL 在执行查询时的动态,因为执行计划在执行查询之前生成 EXPALIN 部分统计信息是估算的,并非精确值...SUBQUERY 在 SUBQUERY 基础上,子查询中的第一个SELECT,取决于外部的查询 DERIVED 在 FROM 列表中包含的子查询,被标记为 DERIVED(衍生),MYSQL会递归执行这些子查询...possible_keys: 指出 MySQL 能使用哪个索引在表中找到记录,查询涉及到的字段上若存在索引,则该索引将被列出,但不一定被查询使用 如果该列是 NULL,则没有相关的索引 key: 显示...MySQL在查询中实际使用的索引,若没有使用索引,显示为 NULL 查询中若使用了覆盖索引,则该索引可能出现在 key 列表,不出现在 possible_keys key_len: 表示索引中使用的字节数
MySQL 子查询 嵌套查询 一、带IN关键字的子查询 二、带EXISTS关键字的查询 三、带ANY、SOME 关键字的子查询 四、带ALL 关键字的查询 自言自语 一、带IN关键字的子查询 使用IN...关键字进行子查询的时候,内层查询语句仅仅返回一个数据列。...语法格式: SELECT 查询字段 FROM 表名 WHERE 字段名 [NOT] IN (SELECT 语句); 二、带EXISTS关键字的查询 意思就是内层的select查到了(至少查到了一行)才进行查询...,没有查到就不进行查询。...只要满足内层子查询中的任何一个比较条件,就返回一个结果作为外层查询的条件。 (满足任意一个) 语法格式: SELECT 查询字段 FROM 表名 WHERE 字段名 比较运算符(>,<..)
目录 联合查询 子查询 分页查询 联合查询 联合查询是指将多个查询结果合并成一个结果集(二维表),通常出现在统计分析中。 语法: 查询语句1 UNION 查询语句2 UNION ......查询语句N 注意: 1.所有查询语句的返回结果的列数必须相等 2.每列的数据类型必须一致,【查询语句1中字段列表的类型必须和查询语句2中的字段列表类型对应且一致】 代码实例: SELECT user_id...子查询分类: 按结果及行数分: 1、 标量子查询(单行子查询:结果集只有一行一列) 2、 列子查询(多行子查询:结果集多行一列) 3、 行子查询(结果集有多行多列) 4、 表子查询(结果集有多行多列)...按出现位置分: 1、 SELECT 后面:只能出现标量子查询 2、 FROM 后面:表子查询(查询结果必须起别名) 3、 WHERE|HAVING:支持标量子查询,列子查询,行子查询 4、 EXISTS...后面:支持表子查询 代码实例: 查询订单信息,并显示用户姓名 SELECT a.
基本查询 SELECT * FROM *表示所有内容 ? 许多检测工具会执行一条SELECT 1; 来测试数据库连接。 2....条件查询 SELECT * FROM WHERE 条件运算按照NOT、AND、OR的优先级进行,即 NOT 最高,其次AND,最后OR 加括号 可以改变 优先级 SELECT...编写一个SQL查询,输出表中所有大国家的名称、人口和面积。...解题: # Write your MySQL query statement below SELECT name, population, area FROM World WHERE population...> 25000000 OR area > 3000000; 格式无特殊要求,好像 # Write your MySQL query statement below SELECT name, population
前言 什么是字符编码,为什么会乱码?...https://zh.wikipedia.org/wiki/%E5%AD%97%E7%AC%A6%E7%BC%96%E7%A0%81 mysql database字符编码默认是latin1,并不支持中文...Linux下的mysql 5.6+版本 其他版本未尝试过,不敢保证可行 解决步骤 查看mysql目前字符编码 #登录mysql mysql -u rrot -p #在mysql中查询字符编码设置 mysql...-----------------------------+----------------------------+ 如果character_set_database = latin1那说明确实是字符编码造成的乱码问题...socket=/var/lib/mysql/mysql.sock # Disabling symbolic-links is recommended to prevent assorted security
因此对于MySQL来说没法使用索引进行join,只能使用Range checked for each record的方式来完成查询。...:彻底弄懂常见的7种中文字符编码 2.2 MySQL中的字符集和字符集排序规则 2.2.1 字符集和字符集排序基本概念 上一节简单介绍了字符集相关的概念,本节开始讲介绍MySQL的字符集以及字符集排序规则相关内容...技术分享 | MySQL 字段长度限制的计算方法 3.2 MySQL中的UTF8和Latin1 为了能够支持中文以及一些其他的非英文文字,开发者经常使用utf8字符集。...以前经常遇到这样一个问题: Latin1字符集是否支持中文? 为了说明这个问题,本文来做如下的测试: 设置终端字符集为utf8。 mysql的所有字符集配置都改成latin1。...表和字段里面的字符集是Latin1,通过终端插入中文正常插入并且正常显示了没有乱码。
limit 基本实现方式 一般情况下,客户端通过传递 pageNo(页码)、pageSize(每页条数)两个参数去分页查询数据库中的数据,在数据量较小(元组百/千级)时使用 MySQL自带的 limit
通过命令查看慢查询最长时间,一般默认10s SHOW VARIABLES LIKE 'long_query_time 我们可以修改该时间,比如我在这里设置为1s,方便测试。...我们必须要打开它, SET GLOBAL slow_query_log=ON; 然后执行一条sql语句,执行时间大于你所设置的long_query_time,我执行了一条sql语句执行时间为1.468s 打开Mysql...查看一下 这里就找到了慢查询日志了。。。...如果你不写 [session|global] 默认是session 会话,指取出当前窗口的执行,如果你想看所有(从mysql 启动到现在,则应该 global) show status like ‘connections...’; //显示慢查询次数 show status like ‘slow_queries’; 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。
领取专属 10元无门槛券
手把手带您无忧上云