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