情景 在centos下部署flask项目,使用的是mariadb,(本地mysql香香的),用到sqlarchemy,插入前中文,出入后查询乱码,最终定位在数据库上, 排查 mysql>show variables...| | character_set_system | utf8 | | character_sets_dir | /usr/share/mysql
MySQL中,数据库的编码是一个相当重要的问题,有时候我们需要查看一下当前数据库的编码,甚至需要修改一下数据库编码。...查看当前数据库编码的SQL语句为: mysql> use xxx Database changed mysql> show variables like 'character_set_database'...查询得到的结果是latin1编码。 下面,我们来修改xxx数据库的编码,把它修改为gb2312。...mysql> alter database xxx CHARACTER SET gb2312; Query OK, 1 row affected (0.00 sec) mysql> show variables...gb2312. 2、再次使用show variables like 'character_set_database'; 来确认一下当前xxx是什么编码。
查询当前用户所有数据库语句(不区分大小写) SHOW DATABASES 结果:
__name__, f()) # 返回当前系统所使用的默认字符编码 p(sys.getdefaultencoding) # 返回用于转换Unicode文件名至系统文件名所使用的编码 p(sys.getfilesystemencoding...) # 获取默认的区域设置并返回元祖(语言, 编码) p(locale.getdefaultlocale) # 返回用户设定的文本数据编码 # 文档提到this function only returns...a guess p(locale.getpreferredencoding) # \xba\xba是'汉'的GBK编码 # mbcs是不推荐使用的编码,这里仅作测试表明为什么不应该用 print r
那么就讲到今天的内容,显示当前查询进度....为什么要显示查询进度 记得在前端时候学过一个知识,就是说用户的等待时间不会超过3秒.意思就是说,当某个界面卡了3秒以上,用户机会觉得体验非常差.如果我们在等待数据中增加一个动画效果,或者提示内容的话虽然解决不了卡的问题...,但是给用的体验相对而言还是不错的.在SAP中我们可以通过调用系统函数的方式进行实现该功能,显示当前查询的进度....案例 我们这里拿VBAP表做一个简单的例子,这个例子是展示当前循环的行数,当循环完成时我们提示一个导入成功 . 数据准备 TABLES :vbap .
mysql获取当前时间的方法:可以通过执行【select now();】语句来获取当前时间。...获得当前日期+时间(date + time)函数:now()mysql> select now(); +———————+ | now() | +———————+ | 2008-08-08 22:20:46...| +———————+ 获得当前日期+时间(date + time)函数:sysdate() sysdate() 日期时间函数跟 now() 类似,不同之处在于:now() 在执行开始时值就得到了,...看下面的例子就明白了:mysql> select now(), sleep(3), now(); +———————+———-+———————+ | now() | sleep(3) | now() |...获得当前时间戳函数:current_timestamp, current_timestamp()mysql> select current_timestamp, current_timestamp()
MySQL联合查询 联合查询:union,将多次查询(多条select语句)的结果,在字段数相同的情况下,在记录的层次上进行拼接。...执行如下 SQL 语句,进行测试: — 联合查询,默认去重 select * from class union distinct select * from class; — 联合查询,保留所有记录 select...特别地,联合查询只要求字段数相同,而跟类型无关。...意义 联合查询的意义有两种,分别为: 查询同一张表,按时需要不同,例如查询学生信息,要求男生按年龄升序排序,女生按年龄降序排序; 多表查询,多张表的结构是完全一样的,保持的数据结构也是一样的。...根据我们刚刚学到的联合查询,貌似很容易啊!
因此对于MySQL来说没法使用索引进行join,只能使用Range checked for each record的方式来完成查询。...后续我也仔细阅读了MySQL的问题,根据我自己的理解之所以设置这个参数,应该是针对于这种情况的: 假设MySQL当前没有character_set_connection这个参数,SQL语句在server...当查询执行完毕之后,返回给客户端的结果使用这个字符集编码。 The character set used for returning query results to the client....所以要说 Latin1支持中文这个说法,其实也对也不对,要根据当前系统的配置才能最后确认Latin1编码下是否支持中文。...,所以整个查询变得非常的慢。
,那我们知道MySql数据库提供了分页的函数limit m,n,但是该函数的用法和我们的需求不一样,所以就需要我们根据实际情况去改写适合我们自己的分页语句,具体的分析如下: 比如: 查询第1条到第10条的数据的...sql是:select * from table limit 0,10; ->对应我们的需求就是查询第一页的数据:select * from table limit (1-1)*10,10; 查询第...10条到第20条的数据的sql是:select * from table limit 10,20; ->对应我们的需求就是查询第二页的数据:select * from table limit (2-1...)*10,10; 查询第20条到第30条的数据的sql是:select * from table limit 20,30; ->对应我们的需求就是查询第三页的数据:select * from table...limit (3-1)*10,10; 二:通过上面的分析,可以得出符合我们自己需求的分页sql格式 mysql分页:select * from 表 limit (pageNo-1)*pageSize,
import chardet print chardet.detect(html)
慢查询日志概念 MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录在MySQL中响应时间超过阀值的语句,具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询日志中...log-slow-queries :旧版(5.6以下版本)MySQL数据库慢查询日志存储路径。...开启了慢查询日志只对当前数据库生效,如果MySQL重启后则会失效。...你用show variables like ‘long_query_time’查看是当前会话的变量值,你也可以不用重新连接会话,而是用show global variables like ‘long_query_time.../mysql/mysql06_slow.log 得到按照时间排序的前10条里面含有左连接的查询语句。
mysql> show variables like 'collation_%'; mysql> show variables like 'character_set_%'; 缺省是latin1编码...修改库的编码: mysql> alter database db_name character set utf8; 修改表的编码: mysql> ALTER TABLE table_name CONVERT...TO CHARACTER SET utf8 COLLATE utf8_general_ci; 可以在mysql中设置编码,单个设置 mysql> set character_set_connection...=utf8; mysql> set character_set_database=utf8; mysql> set character_set_results=utf8; mysql> set character_set_server...,这样确保缺省编码是utf8
= 不相等 > 大于 >= 大于等于 < 小于 <= 小于等于 BETWEEN 位于两个数值之间 查询价格小于10.2的水果 mysql> SELECT f_name,f_price FROM fruits...查询指定范围内的条件记录,将所有的查询条件用括号括起来。...,就返回一个结果作为外层查询的条件。...27 | +------+ 1 row in set (0.00 sec) EXISTS EXISTS 关键字后面的参数是一个任意的子查询,系统对子查询进行运算判断是否返回行,主要至少返回一行,那么EXIST...此时外层语句不做任何查询。
获得当前日期+时间(date + time)函数: select now(); select current_timestamp(); select localtime(); select localtimestamp...(); select sysdate(); 设置默认当前时间: CURRENT_TIMESTAMP 获得当前日期(date)函数: curdate() = current_date() 获得当前时间...(time)函数: curtime() = current_time() 获得当前 UTC 日期时间函数: utc_date(), utc_time(), utc_timestamp()
:索引没有设计好、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 ......子查询分类: 按结果及行数分: 1、 标量子查询(单行子查询:结果集只有一行一列) 2、 列子查询(多行子查询:结果集多行一列) 3、 行子查询(结果集有多行多列) 4、 表子查询(结果集有多行多列)...按出现位置分: 1、 SELECT 后面:只能出现标量子查询 2、 FROM 后面:表子查询(查询结果必须起别名) 3、 WHERE|HAVING:支持标量子查询,列子查询,行子查询 4、 EXISTS...user_id FROM b_order); ANY|SOME t1中有5条记录,每一行的s1去和(select s1 from t2)每一行s1去比较,只要有t1中的s1大于t2中的任意一个s1,那么当前行满足查询条件...ANY|SOME (SELECT s1 FROM t2); ALL t1中有5条记录,每一行的s1去和(select s1 from t2)每一行s1去比较,必须t1中的s1大于t2中的所有的s1,那么当前行满足查询条件
查看当前用户名命令:whoami 如果只是想查看当前登录的用户名,那么很简单,直接使用命令:whoami即可 示例: [root@xxx~]# whoami root 当前示例下的用户名为root。...也可以加空格,使用who am i命令,可以查询到当前登录的用户名、终端类型、时间和IP信息 示例: [root@xxx~]# who am i root pts/3 2019-01...-11 13:02 (36.49.58.93) 如上例所示,当前登录用户为root,伪终端(3号)形式登录,登录时间及登录IP都有显示。...使用w命令查看当前用户及正在使用的进程 使用命令w可以查看当前Linux服务器连接的所有用户及用户正在使用的进程: [root@xxx~]# w 13:07:38 up 3 days, 20:27,...54 0.00s 0.00s -bash root pts/2 36.49.76.93 13:07 1.00s 0.00s 0.00s w 使用who命令查看当前用户的详细信息
基本查询 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
为了实现灵活查询供水管网,根据地址,材质,管径组合汇总查询和条件查询。...(图片数据经过处理,不涉及地理坐标保密信息) 汇总查询,可以用树形子表的方式来组织数据,地址,材质,管径之间的关联信息一目了然,任意维图钻取数据。...image.png image.png image.png 结合条件查询可以在材质-管径-地址三个维度对管网实现任意灵活的查询以及数据分析功能。...,高级查询,排序,分页,过滤,自定义显示列功能,体验友好,支持通过html data标签配置从而零编程实现自己的功能。...initQuerySelects()方法,获取到数据以后才根据数据生成查询下拉列表,此下拉列表进一步可以过滤数据本身。
领取专属 10元无门槛券
手把手带您无忧上云