asp.net 向Oracle資料庫表的Clob欄位中寫入文字編輯器中輸入的大段文字資訊
首先需要一個Oracle操作類,OraDbHelper.cs,程式碼如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data;
using System.Data.OracleClient;
/// <summary>
///OraDbHelper 的摘要說明
/// </summary>
public class OraDbHelper
{
private string connectionString;
/// <summary>
/// 設定資料庫字串的連線
/// </summary>
public string ConnectionString
{
set { connectionString = value; }
}
public OraDbHelper(string connectionString)
{
this.connectionString = connectionString;
}
#region ExecuteDataTable
/// <summary>
/// 執行一個查詢,並返回結果集
/// </summary>
/// <param name="commandText">要執行的查詢SQL文字命令</param>
/// <returns>返回查詢結果集</returns>
public DataTable ExecuteDataTable(string commandText)
{
return ExecuteDataTable(commandText, CommandType.Text, null);
}
/// <summary>
/// 執行一個查詢,並返回查詢結果
/// </summary>
/// <param name="commandText">要執行的SQL語句</param>
/// <param name="commandType">要執行的查詢語句的型別,如儲存過程或者SQL文字命令</param>
/// <returns>返回查詢結果集</returns>
public DataTable ExecuteDataTable(string commandText, CommandType commandType)
{
return ExecuteDataTable(commandText, commandType, null);
}
/// <summary>
/// 執行一個查詢,並返回查詢結果
/// </summary>
/// <param name="commandText">要執行的SQL語句</param>
/// <param name="commandType">要執行的查詢語句的型別,如儲存過程或者SQL文字命令</param>
/// <param name="parameters">PL-SQL 語句或儲存過程的引數陣列</param>
/// <returns></returns>
public DataTable ExecuteDataTable(string commandText, CommandType commandType, params OracleParameter[] parameters)
{
DataTable data = new DataTable();//例項化DataTable,用於裝載查詢結果集
using (OracleConnection connection = new OracleConnection(connectionString))
{
using (OracleCommand command = new OracleCommand(commandText, connection))
{
command.CommandType = commandType;//設定command的CommandType為指定的CommandType
//如果同時傳入了引數,則新增這些引數
if (parameters != null)
{
foreach (OracleParameter parameter in parameters)
{
command.Parameters.Add(parameter);
}
}
//通過包含查詢SQL的SqlCommand例項來例項化SqlDataAdapter
OracleDataAdapter adapter = new OracleDataAdapter(command);
adapter.Fill(data);//填充DataTable
}
}
return data;
}
#endregion ExecuteDataTable
#region ExecuteReader
/// <summary>
/// 將 CommandText 傳送到 Connection 並生成一個 OracleDataReader。
/// </summary>
/// <param name="commandText">要執行的查詢SQL文字命令</param>
/// <returns></returns>
public OracleDataReader ExecuteReader(string commandText)
{
return ExecuteReader(commandText, CommandType.Text, null);
}
/// <summary>
/// 將 CommandText 傳送到 Connection 並生成一個 OracleDataReader。
/// </summary>
/// <param name="commandText">要執行的SQL語句</param>
/// <param name="commandType">要執行的查詢語句的型別,如儲存過程或者SQL文字命令</param>
/// <returns></returns>
public OracleDataReader ExecuteReader(string commandText, CommandType commandType)
{
return ExecuteReader(commandText, commandType, null);
}
/// <summary>
/// 將 CommandText 傳送到 Connection 並生成一個 OracleDataReader。
/// </summary>
/// <param name="commandText">要執行的SQL語句</param>
/// <param name="commandType">要執行的查詢語句的型別,如儲存過程或者SQL文字命令</param>
/// <param name="parameters">Transact-SQL 語句或儲存過程的引數陣列</param>
/// <returns></returns>
public OracleDataReader ExecuteReader(string commandText, CommandType commandType, OracleCommand[] parameters)
{
OracleConnection connection = new OracleConnection(connectionString);
OracleCommand command = new OracleCommand(commandText, connection);
//如果同時傳入了引數,則新增這些引數
if (parameters != null)
{
foreach (OracleCommand parameter in parameters)
{
command.Parameters.Add(parameter);
}
}
connection.Open();
//CommandBehavior.CloseConnection引數指示關閉Reader物件時關閉與其關聯的Connection物件
return command.ExecuteReader(CommandBehavior.CloseConnection);
}
#endregion ExecuteReader
#region ExecuteScalar
/// <summary>
/// 從資料庫中檢索單個值(例如一個聚合值)。
/// </summary>
/// <param name="commandText">要執行的查詢PL-SQL文字命令</param>
/// <returns></returns>
public Object ExecuteScalar(string commandText)
{
return ExecuteScalar(commandText, CommandType.Text, null);
}
/// <summary>
/// 從資料庫中檢索單個值(例如一個聚合值)。
/// </summary>
/// <param name="commandText">要執行的SQL語句</param>
/// <param name="commandType">要執行的查詢語句的型別,如儲存過程或者PL-SQL文字命令</param>
/// <returns></returns>
public Object ExecuteScalar(string commandText, CommandType commandType)
{
return ExecuteScalar(commandText, commandType, null);
}
/// <summary>
/// 從資料庫中檢索單個值(例如一個聚合值)。
/// </summary>
/// <param name="commandText">要執行的SQL語句</param>
/// <param name="commandType">要執行的查詢語句的型別,如儲存過程或者SQL文字命令</param>
/// <param name="parameters">PL-SQL 語句或儲存過程的引數陣列</param>
/// <returns></returns>
public Object ExecuteScalar(string commandText, CommandType commandType, OracleParameter[] parameters)
{
object result = null;
using (OracleConnection connection = new OracleConnection(connectionString))
{
using (OracleCommand command = new OracleCommand(commandText, connection))
{
command.CommandType = commandType;//設定command的CommandType為指定的CommandType
//如果同時傳入了引數,則新增這些引數
if (parameters != null)
{
foreach (OracleParameter parameter in parameters)
{
command.Parameters.Add(parameter);
}
}
connection.Open();//開啟資料庫連線
result = command.ExecuteScalar();
}
}
return result;//返回查詢結果的第一行第一列,忽略其它行和列
}
#endregion ExecuteScalar
#region ExecuteNonQuery
/// <summary>
/// 對資料庫執行增刪改操作
/// </summary>
/// <param name="commandText">要執行的查詢pl-sql文字命令</param>
/// <returns></returns>
public int ExecuteNonQuery(string commandText)
{
return ExecuteNonQuery(commandText, CommandType.Text, null);
}
/// <summary>
/// 對資料庫執行增刪改操作
/// </summary>
/// <param name="commandText">要執行的pl-sql語句</param>
/// <param name="commandType">要執行的查詢語句的型別,如儲存過程或者pl-sql文字命令</param>
/// <returns></returns>
public int ExecuteNonQuery(string commandText, CommandType commandType)
{
return ExecuteNonQuery(commandText, commandType, null);
}
/// <summary>
/// 對資料庫執行增刪改操作
/// </summary>
/// <param name="commandText">要執行的pl-sql語句</param>
/// <param name="commandType">要執行的查詢語句的型別,如儲存過程或者pl-sql文字命令</param>
/// <param name="parameters">pl-sql 語句或儲存過程的引數陣列</param>
/// <returns>返回執行操作受影響的行數</returns>
public int ExecuteNonQuery(string commandText, CommandType commandType, OracleParameter[] parameters)
{
int count = 0;
using (OracleConnection connection = new OracleConnection(connectionString))
{
using (OracleCommand command = new OracleCommand(commandText, connection))
{
command.CommandType = commandType;//設定command的CommandType為指定的CommandType
//如果同時傳入了引數,則新增這些引數
if (parameters != null)
{
foreach (OracleParameter parameter in parameters)
{
command.Parameters.Add(parameter);
}
}
connection.Open();//開啟資料庫連線
count = command.ExecuteNonQuery();
}
}
return count;//返回執行增刪改操作之後,資料庫中受影響的行數
}
#endregion ExecuteNonQuery
}
cs程式碼中呼叫程式碼如下:
OraDbHelper dbHelper = new OraDbHelper(System.Configuration.ConfigurationManager.ConnectionStrings["OracleConnectionString"].ConnectionString.ToString());
string sql = "insert into SYIT_POSTINFORM " +
" ( ZYXTYPE,GRADENM,TITLE,FBRNM,FBTM,YXTM,CONTS,FROMSR) values ";
sql += "( '" + sclass + "'";
sql += ", '" + gwxx[1] + "'";
sql += ", '" + gwxx[0] + "'";
sql += ",' " + gwxx[2] + "'";
sql += ", to_date('" + gwxx[3] + "','yyyy/MM/DD')";
sql += ", to_date('" + gwxx[5] + "','yyyy/MM/DD')";
sql += ", :lgContent ";
sql += ", '" + gwxx[4] + "'";
sql += " )";
OracleParameter[] parameters = {
new OracleParameter("lgContent",OracleType.Clob)
};
parameters[0].Value = gwxx[6];
dbHelper.ExecuteNonQuery(sql, CommandType.Text, parameters);
相關文章
- 保留資料庫表中的資料,把表中的欄位varchar2改成clob型別資料庫型別
- 向資料庫中全部表中增加一個欄位的SQL資料庫SQL
- 【Linux】中預設文字編輯器 vim 的入門與進階Linux
- SQL Server中text型別匯入oracle clob欄位時的設定SQLServer型別Oracle
- 使用sqlloader向oracle匯入文字資料SQLOracle
- MySQL資料庫中庫、表名、欄位的大小寫問題MySql資料庫
- asp.net文字編輯器(FCKeditor)ASP.NET
- Oracle中Blob欄位的寫入處理(一) (轉)Oracle
- Java編寫的文字編輯器(菜鳥作品)Java
- 日常筆記一:擷取富文字編輯器中的文字內容筆記
- 在Delphi中處理資料庫日期型欄位的顯示與輸入 (轉)資料庫
- 將informix匯出的文字資料匯入oracle資料庫ORMOracle資料庫
- 使用FSO把文字資訊匯入資料庫 (轉)資料庫
- UltraEdit文字編輯器編寫強大的宏教程
- 一次防止瀏覽器裡輸入的大段文字防止丟失的巧合的解決方案瀏覽器
- Oracle工具之sqlldr的使用--如何將文字檔案或Excel中的資料匯入資料庫OracleSQLExcel資料庫
- EXCEL中如何橫向輸入資料?Excel
- 深度學習中,影像和文字的輸入區別深度學習
- 教你如何完美儲存Html編輯器編輯過的文字到Word中HTML
- 泛微oa流程表單之明細表欄位通過文字輸入內容使另外一個欄位必填
- 使用oracle sqlldr匯入文字資料的例子OracleSQL
- 利用PLSQL包載入CLOB欄位SQL
- 將選中的下拉選單值寫入文字框
- 對資料庫中的表或欄位重新命名資料庫
- 文字檔案用sqlldr工具匯入到oracel資料庫中SQL資料庫
- Oracle lob載入bfile資料到blob欄位中Oracle
- Windows 8.1的輸入法編輯器Windows
- 如何在模板中編輯修改文字
- [Djangorestframework]-富文字編輯器的使用DjangoRESTFramework
- Windows下好用的文字編輯器Windows
- 如何在Oracle資料庫中查詢表和欄位說明Oracle資料庫
- nlp中文字輸入的資料預處理方式
- 如何在Clob欄位中查詢
- 簡單好用的文字編輯器《Simditor》外掛快速入門例項
- 關於oracle中blob欄位的錄入問題Oracle
- 文字直接寫資料庫資料庫
- Typora for Mac(文字編輯器)Mac
- 富文字編輯器初探