使用mysql innodb 使用5.7的json類型遇到的坑和解決辦法


----------------------------------------------

#查詢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、使用外部計數器,比如建立一個觸發器來計數或者在程序上使用緩存方式定時計數,缺陷是這些方法會額外消耗一些資源!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM