使用mysql innodb 使用5.7的json类型遇到的坑和解决办法
2023-09-11 14:21:33 时间
----------------------------------------------
#查询JSON的某个字段 select data -> '$.Host' from temp #创建虚拟列 ALTER TABLE temp ADD host varchar(128) GENERATED ALWAYS AS (json_extract(data,'$.Host')) VIRTUAL; #给虚拟列创建索引 ALTER TABLE temp ADD INDEX index_temp_host ( host)
#用建立的第二索引列解决select count 的效率问题
select count(0) from temp where host>=0 ;
#设置mysql日志目录 & 启用日志
SHOW VARIABLES LIKE "general_log%"; SET GLOBAL general_log = 'ON';
SET GLOBAL general_log_file = 'd:/mysql.log'
-------------------------------------------------------
EntityFramework不能使用mysql5.7的解决办法。【MySQL - Entity : The value for column 'IsPrimaryKey' in table 'TableDetails' is DBNull】
(目前测试:EntityFramework不能使用mysql5.7中的Json类型,Ado.net可以使用json类型)
在mysql执行一段代码就可以用entityframework了
use adventureworks; set global optimizer_switch='derived_merge=off'; set optimizer_switch='derived_merge=off'; select @@optimizer_switch; select @@GLOBAL.optimizer_switch;
public static DataTable ExecuteDataTable(string sql, params MySqlParameter[] parameters) { MySqlConnection con = new MySqlConnection("server=localhost;user id=root;password=aaa_123;port=4407;database=testjson"); con.Open(); MySqlCommand cmd = new MySqlCommand(sql, con); foreach (MySqlParameter parameter in parameters) { cmd.Parameters.Add(parameter); } DataSet dataset = new DataSet();//dataset放执行后的数据集合 MySqlDataAdapter adapter = new MySqlDataAdapter(cmd); adapter.Fill(dataset); cmd.Dispose(); con.Close(); return dataset.Tables[0]; }
-----------------------------------------------------
关于mysql innodb count(*)速度慢的解决办法
innodb引擎在统计方面和myisam是不同的,Myisam内置了一个计数器,所以在使用 select count(*) from table 的时候,直接可以从计数器中取出数据。而innodb必须全表扫描一次方能得到总的数量。要初步解决这个问题,需要做不同于myisam的一些工作:
1、使用第二索引(一般不使用主键索引),并且添加where条件,如:
select count(*) from product where comp_id>=0 ;
show index from product ;
id primary key
comp_id index
2、如果只需要粗略统计的话也可使用
show status from product; 来得到大约值
这种方法可在数据分页中使用!
3、使用外部计数器,比如建立一个触发器来计数或者在程序上使用缓存方式定时计数,缺陷是这些方法会额外消耗一些资源!
相关文章
- MySQL忘记root密码解决办法
- MySQL 5.7 新特性 generated columns
- 【MySQL】批量删除mysql中数据库中的表
- Mysql: 强制走索引:mysql between 日期索引 索引问题-日期索引使用
- ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
- ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var mysql 启动不了
- mysql的二级索引
- 谈谈 MySQL 的 JSON 数据类型
- MySQL加锁处理分析(转)
- win7 第一次装 mysql-5.7.16-winx64 ,不知道root 密码,该如何处理?
- mysql新增加用户
- Mysql备份工具比较
- MYSQL错误解决:ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
- Mysql数据导入导出
- mysql 有报错 ERROR! MySQL is not running, but lock file (/var/lock/subsys/mysql) exists
- mysql 的列类型,增加更新表字段
- MySql中json类型的使用___mybatis存取mysql中的json
- Mysql 如果有多个可选条件怎么加索引_MySQL|mysql-索引
- MySQL用户权限(Host,User,Password)管理(mysql.user)
- mysql数据表简单拷贝及重命名
- mysql-connector-java与Mysql、Java的对应版本
- Mysql 命令 load data infile 权限问题
- Mysql报错:Can't connect to local MySQL server through socket '/tmp/mysql.sock'
- MySQL远程连接报错2003-cant connection to mysql server on ‘IP’(10061 unknown error)
- Mysql之加密连接mysql_ssl_rsa_setup
- Mysql安装多台mysql
- 【MySQL】数据库基础知识_Unit01
- MySQL ---- SQL语句学习笔记二
- MySQL计算时间差函数
- [MySQL] 解决办法: Error: Transaction test error: file /etc/my.cnf from install of mysql-community-server