Access數(shù)據(jù)庫(kù)多條數(shù)據(jù)Insert
來(lái)源:易賢網(wǎng) 閱讀:733 次 日期:2014-10-16 09:23:19
溫馨提示:易賢網(wǎng)小編為您整理了“Access數(shù)據(jù)庫(kù)多條數(shù)據(jù)Insert”,方便廣大網(wǎng)友查閱!

當(dāng)下Access數(shù)據(jù)庫(kù)可能要被遺忘了!比較這個(gè)輕量級(jí)數(shù)據(jù)庫(kù)被精簡(jiǎn)了許多功能,個(gè)人感覺(jué)用起來(lái)還是挺麻煩的!當(dāng)前Access在企業(yè)項(xiàng)目中就是一塊雞肋。數(shù)據(jù)量小使用SQL Server是浪費(fèi),既然選擇了Access就別抱怨了!如果用好了還是一塊寶!廢話不多說(shuō)了,今天就來(lái)探討下如何向Access中插入多條數(shù)據(jù)把!

由于在此之前我沒(méi)有用過(guò)Access數(shù)據(jù)庫(kù)的,當(dāng)需要想數(shù)據(jù)庫(kù)中插入多條數(shù)據(jù)時(shí),我們不妨先按照sql server的做法:“insert into tablename(column1,column2) values (a,b),(c,d),(e,f)”。于是按照這個(gè)思路,我的第一個(gè)方案出來(lái)了。

嘗試一:

The Demo:

StringBuilder BuiList = new StringBuilder(string.Format("({0},0)", UserID));

foreach (RepeaterItem item in Rpt_AdminRole.Items)

{

if (item.ItemType == ListItemType.Item || item.ItemType == ListItemType.AlternatingItem)

{

HtmlInputCheckBox cbRole = item.FindControl("cb_Role") as HtmlInputCheckBox;

if (cbRole.Checked)

{

BuiList.Append(",(");

BuiList.Append(UserID);

BuiList.Append(",");

BuiList.Append(cbRole.Value);

BuiList.Append(")");

}

}

}

The Dal:

/// <summary>

/// 添加Role關(guān)系

/// </summary>

/// <param name="roleContact">角色關(guān)系 eg: "(1,1),(1,2)"</param>

/// <returns></returns>

public static int InsertRoleContact(string roleContact)

{

string sql = "insert into Sky_Admin_Role(AdminID,RoleID) values "+roleContact;

return Common.OleDbHelper.ExecuteNonQuery(CommandType.Text, sql, null);

}

exec下就會(huì)出現(xiàn)這樣的錯(cuò)誤:SQL 語(yǔ)句的結(jié)束位置缺少分號(hào) (;)。

Access對(duì)sql的支持果然是大大精簡(jiǎn),到此嘗試一失??!, 很快在我有另外idea。sql server 多表查詢對(duì)select table 的支持!我可以直接傳一個(gè)DataTable到sql語(yǔ)句中,說(shuō)干就干!

嘗試二

The Demo : 獲取DataTable

public DataTable GetInsertSQL(Repeater rep,string controlID)

{

DataTable data = new DataTable();

data.Columns.Add("AdminID");

data.Columns.Add("RoleID");

foreach (RepeaterItem item in rep.Items)

{

if (item.ItemType == ListItemType.Item || item.ItemType == ListItemType.AlternatingItem)

{

HtmlInputCheckBox cb = item.FindControl(controlID) as HtmlInputCheckBox;

if (cb.Checked)

{

DataRow row = data.NewRow();

row.ItemArray = new object[] { UserID, cb.Value};

data.Rows.Add(row);

}

}

}

return data;

}

The Dal:

public static int InsertRoleContact(DataTable dt)

{

string sql = "insert into Sky_Admin_Role(AdminID,RoleID) select * from @Data";

OleDbParameter[] param = new OleDbParameter[] {

new OleDbParameter("@Data",?){Value =dt}

};

return Common.OleDbHelper.ExecuteNonQuery(CommandType.Text, sql, param);

}

當(dāng)代碼到這里我就知道此方法行不通,因?yàn)镺ledbType中沒(méi)有對(duì)應(yīng)的table類型,如果是SQL server由于支持xml可以設(shè)置為 SqlDbType.Xml類型來(lái)傳遞DataTable數(shù)據(jù),由于sql本事對(duì)xml的支持 ,可以用sql基于xml的查詢,本文主要討論Access,此處暫不討論了!嘗試二宣布失??!。接下來(lái)我又想到了零時(shí)表,Access是不是也支持零時(shí)表的查詢呢?

嘗試三

The Demo: 取出我想要的數(shù)據(jù)格式 (1,2,3)

public string GetInserCollection(Repeater rep, string controlID)

{

StringBuilder buiCollecton = new StringBuilder("");

buiCollecton.Append("(0");

foreach (RepeaterItem item in rep.Items)

{

if (item.ItemType == ListItemType.Item || item.ItemType == ListItemType.AlternatingItem)

{

HtmlInputCheckBox cb = item.FindControl(controlID) as HtmlInputCheckBox;

if (cb.Checked)

{

buiCollecton.Append(string.Format(",{0}", cb.Value));

}

}

}

buiCollecton.Append(")");

return buiCollecton.ToString();

}

The Dal :

public static int InsertRoleContact(int UserID,string RoleCollection)

{

StringBuilder BuiSQL = new StringBuilder("");

BuiSQL.Append("declare @SkyContact table(userID int,roleID int);");

BuiSQL.Append("insert into @SkyContact values select " + UserID + ",R_ID from Sky_Role;");

BuiSQL.Append(string.Format("insert into Sky_Admin_Role values (select * from @SkyContact where roleID in {0})",RoleCollection));

return Common.OleDbHelper.ExecuteNonQuery(CommandType.Text, BuiSQL.ToString(), null);

}

這里模仿SQL Server中定義一個(gè)零時(shí)表,然后向其中插入盡可能全的數(shù)據(jù),然后在基于零時(shí)表查詢出想要的數(shù)據(jù)放入到我想要的數(shù)據(jù)中執(zhí)行!exec下結(jié)果又出問(wèn)錯(cuò)了!此處拋出這樣的錯(cuò)誤:無(wú)效的 SQL語(yǔ)句;期待 'DELETE'、'INSERT'、'PROCEDURE'、'SELECT'、或 'UPDATE'。其實(shí)會(huì)出錯(cuò)完全可以想想的到,畢竟Access中連insert into table values (1,2),(1,3) 這樣的語(yǔ)句都不支持。此時(shí)嘗試三也不得不宣告失?。L試了這么多,我不得不使用早就準(zhǔn)備用的方法 多條insert一起執(zhí)行。

嘗試四

The Demo: 先獲取我想要的數(shù)據(jù)形式 :1,2,3 此處略。看sql:

public static int InsertRoleContact2(int UserID, string RoleCollection)

{

string[] arr = RoleCollection.Split(',');

StringBuilder BuilSQL = new StringBuilder("");

foreach (string item in arr)

{

BuilSQL.Append(

string.Format("insert into Sky_Admin_Role(AdminID,RoleID) values ({0},{1});",UserID,Convert.ToInt32(item)));

}

return Common.OleDbHelper.ExecuteNonQuery(CommandType.Text, BuilSQL.ToString(), null);

}

執(zhí)行下結(jié)果打出我的意外:在 SQL 語(yǔ)句結(jié)尾之后找到字符。 竟然連這種語(yǔ)句都不支持,沒(méi)相當(dāng)Access會(huì)對(duì)數(shù)據(jù)支持的這么少。既然這樣也不行,難道只有循環(huán)執(zhí)行每一天SQL語(yǔ)句嗎?我看可行!循環(huán)是必要的,只要不多次連接數(shù)據(jù)庫(kù),也不會(huì)占用太多資源的,此時(shí)引出了我的本文的重點(diǎn),如何向Access中插入多條記錄。

嘗試五

The Demo:

public static void InsertMultipleSQL(int UserID,string RoleCollection)

{

string[] arr = RoleCollection.Split(',');

using (OleDbConnection conn = new OleDbConnection(Common.config.AccessConnStr))

{

OleDbCommand cmd = conn.CreateCommand();

OleDbTransaction trans = null;

try

{

conn.Open();

trans = conn.BeginTransaction();

cmd.Transaction = trans;

foreach (string item in arr)

{

cmd.CommandText =

string.Format(

string.Format(

"insert into Sky_Admin_Role(AdminID,RoleID

) values ({0},{1});", UserID, Convert.ToInt32(item)));

cmd.ExecuteNonQuery();

}

trans.Commit();

}

catch (Exception ex)

{

trans.Rollback();

throw ex;

}

}

}

注意當(dāng)插入多條語(yǔ)句時(shí)我們不要忘了一旦發(fā)生異常,我們需要撤銷操作,就必須要用到事務(wù)。執(zhí)行Aceess的insert時(shí),我們需要在connection關(guān)閉前循環(huán)插入,這樣才能減少資源暫用,提升性能。這里宣告嘗試五成功!

更多信息請(qǐng)查看IT技術(shù)專欄

更多信息請(qǐng)查看數(shù)據(jù)庫(kù)
易賢網(wǎng)手機(jī)網(wǎng)站地址:Access數(shù)據(jù)庫(kù)多條數(shù)據(jù)Insert
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 加入群交流 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)