mysql 數(shù)據(jù)庫(kù)鏈接狀態(tài)確認(rèn)實(shí)驗(yàn)(推薦)
1.起因:
在做一個(gè)小系統(tǒng)的時(shí)候,我想數(shù)據(jù)量交互不大,就都用一個(gè)鏈接執(zhí)行算了,還能節(jié)省點(diǎn)資源,但是實(shí)際情況遇到了如下問(wèn)題,在使用的過(guò)程中,有些數(shù)據(jù)操作會(huì)被轉(zhuǎn)移到其他線程,這樣;我這個(gè)簡(jiǎn)單的想法遇到了問(wèn)題,因?yàn)橐粋€(gè)現(xiàn)場(chǎng)在使用這個(gè)鏈接的時(shí)候,其他線程也會(huì)同步插入執(zhí)行數(shù)據(jù)操作,這樣一個(gè)鏈接就會(huì)面臨共用的沖突,怎么辦呢,有如下三種方案:
1.1.數(shù)據(jù)兩次一次一聯(lián),一用,一釋放。
1.2.強(qiáng)制是數(shù)據(jù)庫(kù)的執(zhí)行放到一個(gè)現(xiàn)場(chǎng),那么得把所有的執(zhí)行參數(shù)放到隊(duì)列中,有數(shù)據(jù)支持的線程按照隊(duì)列的順序執(zhí)行。也可以在使用的時(shí)候把鏈接索起來(lái)。這樣強(qiáng)制的使數(shù)據(jù)的處理串行。
1.3.做一個(gè)內(nèi)部的鏈接對(duì)象使用池,池中的對(duì)象可供服用,解決重復(fù)鏈接的問(wèn)題,提供多個(gè)對(duì)象解決現(xiàn)場(chǎng)使用沖突的問(wèn)題。
我選擇了方案三,做了如下實(shí)驗(yàn),記錄如下
2.實(shí)驗(yàn)
2.1 確認(rèn)數(shù)據(jù)鏈接狀態(tài),使用完的數(shù)據(jù)鏈接是什么狀態(tài)呢?
2.1.1 目的:我想根據(jù)鏈接的狀態(tài)判斷鏈接是在使用中,還是可以給別人使用;就是在可以使用的情況下,我就用該鏈接執(zhí)行,否則使用或者創(chuàng)建其他的鏈接。
代碼。
using System; using System.Data; namespace 數(shù)據(jù)庫(kù)鏈接狀態(tài)確認(rèn) { /// <summary> /// 確認(rèn)數(shù)據(jù)庫(kù)通常執(zhí)行完成是什么狀態(tài) /// </summary> public class Test1:Singleton<Test1> { public void main() { test1(); } private void test1() { DBmsqlSub dBmsqlSub = new DBmsqlSub(); string sql = "insert into tb1(v1) values(2)"; dBmsqlSub.ExecuteNonQuery(sql); ConnectionState connectionState = dBmsqlSub.getState(); Console.WriteLine(connectionState); dBmsqlSub.Close(); } } }
結(jié)果,整理使用后的鏈接狀態(tài)是open,那是不是open的時(shí)候就可以供別人使用了呢,要是在執(zhí)行的時(shí)候也是open狀態(tài),那我就沒(méi)有判定已經(jīng)了。
數(shù)據(jù)庫(kù)鏈接狀態(tài)確認(rèn) id0 index:1 isuser:False setuser:False Open
2.2 數(shù)據(jù)庫(kù)在執(zhí)行的時(shí)候,是不是有一個(gè)執(zhí)行中的狀態(tài)呢?
代碼
using System; using System.Threading.Tasks; namespace 數(shù)據(jù)庫(kù)鏈接狀態(tài)確認(rèn) { /// <summary> /// 目的:確認(rèn)執(zhí)行中的數(shù)據(jù)狀態(tài) /// </summary> class Test2:Singleton<Test2> { public void main() { DBmsqlSub dBmsqlSub = new DBmsqlSub(); Task.Factory.StartNew(test2Exe, (Object)dBmsqlSub); Task.Factory.StartNew(test2Exe, (Object)dBmsqlSub); Task.Factory.StartNew(test2State, dBmsqlSub); } private void test2Exe(object dBmsqlSub) { int index = 1; while (true) { index++; string sql = "insert into tb1(v1) values(" + index + ")"; ((DBmsqlSub)dBmsqlSub).ExecuteNonQuery(sql); Task.Delay(200); } } private void test2State(object dBmsqlSub) { while (true) { Console.WriteLine(((DBmsqlSub)dBmsqlSub).getState()); } } } }
行結(jié)果執(zhí):即使執(zhí)行中,對(duì)象的鏈接狀態(tài)依然是open,那么用鏈接狀態(tài)作為鏈接是否可用的計(jì)劃泡湯了,那就只能用自添加的對(duì)象來(lái)控制鏈接是否可用了。
Open
Open
Open
Open
id0
Open
Open
Open
Open
Open
Open
2.3 測(cè)試3:添加對(duì)象的狀態(tài),控制鏈接是否可用
2.3.1 代碼
using MySqlConnector; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace 數(shù)據(jù)庫(kù)鏈接狀態(tài)確認(rèn) { class Test3:Singleton<Test3> { public void main() { test1(); //test1(); } private void test1() { Task.Factory.StartNew(test2Exe); Task.Factory.StartNew(test2Exe); Task.Factory.StartNew(test2Exe); } private void test2Exe() { int index = 1; while (true) { index++; string sql = "insert into tb1(v1) values(" + index + ")"; DBmsql.getMy().ExecuteNonQuery(sql); } } private object MySqlDataReader(DBmsqlSub dBmsqlSub) { throw new NotImplementedException(); } private void test2State(object dBmsqlSub) { while (true) { Console.WriteLine(((DBmsqlSub)dBmsqlSub).getState()); } } } }
2.3.2
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace 數(shù)據(jù)庫(kù)鏈接狀態(tài)確認(rèn) { class DBmsql : Singleton<DBmsql> { List<DBmsqlSub> dBmsqlSubs = new List<DBmsqlSub>(); /// <summary> /// 執(zhí)行sql命令 /// </summary> /// <param name="CommandText"></param> public void ExecuteNonQuery(String CommandText) { getDBmsqlSub().ExecuteNonQuery(CommandText); } /// <summary> /// 插入數(shù)據(jù),并返回插入數(shù)據(jù)的id /// </summary> /// <param name="CommandText"></param> /// <returns></returns> public int insertReturn(string CommandText) { int ret = getDBmsqlSub().insertReturn(CommandText); return ret; } /// <summary> /// 執(zhí)行并返回一個(gè)對(duì)象 /// </summary> /// <param name="CommandText"></param> /// <returns></returns> public object ExecuteScalar(string CommandText) { object o = getDBmsqlSub().ExecuteScalar(CommandText); return o; } /// <summary> /// 獲取數(shù)據(jù)處理對(duì)象 /// </summary> /// <returns></returns> private DBmsqlSub getDBmsqlSub() { DBmsqlSub ret = null; lock (dBmsqlSubs) { //避免兩個(gè)同時(shí)取到允許的狀態(tài) foreach (DBmsqlSub dBmsqlSub in dBmsqlSubs) { if (!dBmsqlSub.IsUrse()) { ret = dBmsqlSub; dBmsqlSub.setIsUser(true); Console.WriteLine("get:" + ret.id); break; } } //避免兩個(gè)同時(shí)創(chuàng)建對(duì)象,產(chǎn)生結(jié)果列表的錯(cuò)誤 if (ret == null&& dBmsqlSubs.Count<90) { DBmsqlSub dBmsqlSub = new DBmsqlSub(); dBmsqlSubs.Add(dBmsqlSub); dBmsqlSub.setIsUser(true); ret = dBmsqlSub; Console.WriteLine("get:" + ret.id); } } return ret; } } }
2.3.3
using MySqlConnector; using System; using System.Collections.Generic; using System.Data; using System.Linq; using System.Text; using System.Threading.Tasks; namespace 數(shù)據(jù)庫(kù)鏈接狀態(tài)確認(rèn) { public class Constand { public static string mesConnStr = "server=localhost;port=3306;database=db1;user id=root;password=123456;Charset=utf8;"; } class DBmsqlSub { static int index = 0; public int id = 0; private bool isUser = false; private static NLog.Logger logger = NLog.LogManager.GetCurrentClassLogger(); MySqlConnection mConn; MySqlCommand mCmd; public void setIsUser(bool value) { lock (this) { Console.WriteLine("index:" + index + " isuser:" + isUser+" setuser:"+ value); isUser = value; } } public MySqlDataReader MySqlDataReader { get; private set; } public DBmsqlSub() { id = index++; try { mConn = new MySqlConnection(Constand.mesConnStr); mConn.Open(); mCmd = new MySqlCommand(); mCmd.Connection = mConn; } catch (Exception e) { logger.Error(e.ToString()); } } ~DBmsqlSub() { mConn.Close(); } public void Close() { mConn.Close(); } public bool isOpen() { if (mConn.State == ConnectionState.Closed) { mConn.Open(); } if (mConn.State == ConnectionState.Open) { return true; } else { return false; } } public MySqlCommand getCmd() { return mCmd; } /// <summary> /// 如果沒(méi)有鏈接,就直接鏈接 /// </summary> private void conn() { if (mConn.State != ConnectionState.Open) { mConn.Open(); } } /// <summary> /// 執(zhí)行sql命令 /// </summary> /// <param name="CommandText"></param> public void ExecuteNonQuery(String CommandText) { //setIsUser(true); mCmd.CommandText = CommandText; try { Console.WriteLine("id"+id); mCmd.ExecuteNonQuery(); } catch (Exception ex) { logger.Error(ex.ToString()); } finally { setIsUser(false); } } /// <summary> /// 插入數(shù)據(jù),并返回插入數(shù)據(jù)的id /// </summary> /// <param name="CommandText"></param> /// <returns></returns> public int insertReturn(string CommandText) { setIsUser(true); int ret = 0; MySqlTransaction sqlTransaction = mConn.BeginTransaction(); try { mCmd.CommandText = CommandText; object o = mCmd.ExecuteScalar(); sqlTransaction.Commit(); ret = int.Parse(o.ToString()); } catch (Exception e) { logger.Error(e.ToString()); sqlTransaction.Rollback(); } finally { setIsUser(false); } return ret; } /// <summary> /// 執(zhí)行并返回一個(gè)對(duì)象 /// </summary> /// <param name="CommandText"></param> /// <returns></returns> public object ExecuteScalar(string CommandText) { setIsUser(true); object o = null; mCmd.CommandText = CommandText; try { o = mCmd.ExecuteScalar(); } catch (Exception ex) { logger.Error(ex.ToString()); } finally { setIsUser(false); } return o; } public MySqlDataReader ExecuteReader(string CommandText) { setIsUser(true); MySqlDataReader mySqlDataReader = null; mCmd.CommandText = CommandText; try { mySqlDataReader = mCmd.ExecuteReader(); //mConn.Close(); } catch (Exception ex) { logger.Error(ex.ToString()); } finally { setIsUser(false); } return mySqlDataReader; } public ConnectionState getState() { return mConn.State; } public bool IsUrse() { return isUser; } } }
2.3.4
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace 數(shù)據(jù)庫(kù)鏈接狀態(tài)確認(rèn) { /// <summary> /// 單件構(gòu)象基類 /// </summary> /// <typeparam name="T"></typeparam> public class Singleton<T> where T : new() { static T t = default(T); public static T getMy() { if (t == null) { t = new T(); } return t; } } }
運(yùn)行結(jié)果:可用看出是幾個(gè)鏈接對(duì)象在被循環(huán)的使用,也基本達(dá)到了直接的初衷,用盡可能少的鏈接,完成多線程的調(diào)用情景。
id2 index:5 isuser:True setuser:False index:5 isuser:False setuser:True index:5 isuser:True setuser:False get:3 id3 index:5 isuser:False setuser:True get:4 id4 index:5 isuser:True setuser:False index:5 isuser:False setuser:True get:2 id2 index:5 isuser:True setuser:False index:5 isuser:False setuser:True get:3 id3
到此這篇關(guān)于mysql 數(shù)據(jù)庫(kù)鏈接狀態(tài)確認(rèn)實(shí)驗(yàn)的文章就介紹到這了,更多相關(guān)mysql 數(shù)據(jù)庫(kù)鏈接狀態(tài)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Django2.* + Mysql5.7開(kāi)發(fā)環(huán)境整合教程圖解
這篇文章主要介紹了Django2.* + Mysql5.7開(kāi)發(fā)環(huán)境整合教程,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09mysql8.0?lower_case_table_names?大小寫(xiě)敏感設(shè)置問(wèn)題解決
在默認(rèn)情況下,這個(gè)變量是設(shè)置為0的,以保持向前兼容性,如果將該變量設(shè)置為1,則表名和數(shù)據(jù)庫(kù)名將被區(qū)分大小寫(xiě),本文主要介紹了mysql8.0?lower_case_table_names?大小寫(xiě)敏感設(shè)置問(wèn)題解決,感興趣的可以了解一下2023-09-09允許任意IP訪問(wèn)mysql數(shù)據(jù)庫(kù)的方法詳解
MYSQL默認(rèn)只能本地連接,即127.0.0.1和localhost,其他主機(jī)IP無(wú)法訪問(wèn)數(shù)據(jù)庫(kù),那么如何允許任意IP訪問(wèn)mysql數(shù)據(jù)庫(kù),所以本文小編將給大家介紹允許任意IP訪問(wèn)mysql數(shù)據(jù)庫(kù)的方法,文中通過(guò)代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01MySQL數(shù)據(jù)中很多換行符和回車符的解決方法
這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)中很多換行符和回車符的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10MySQL入門(mén)完全指南及Linux系統(tǒng)下基本的安裝教程
這篇文章主要介紹了MySQL入門(mén)完全指南及Linux系統(tǒng)下基本的安裝教程,對(duì)MySQL的基本特性有一個(gè)較為詳細(xì)的整理,需要的朋友可以參考下2015-11-11MySQL?原理優(yōu)化之Group?By的優(yōu)化技巧
這篇文章主要介紹了MySQL?原理優(yōu)化之Group?By的優(yōu)化技巧,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-08-08MySQL數(shù)據(jù)庫(kù)開(kāi)啟、關(guān)閉、查看函數(shù)功能的方法
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)開(kāi)啟、關(guān)閉、查看函數(shù)功能的方法,本文為解決一個(gè)錯(cuò)誤總結(jié)而來(lái),錯(cuò)誤信息本文一同給出,需要的朋友可以參考下2014-10-10