12 changed files with 1003 additions and 39 deletions
@ -0,0 +1,686 @@ |
|||||
|
using System; |
||||
|
using System.Collections.Generic; |
||||
|
using System.Linq; |
||||
|
using System.Text; |
||||
|
using System.Threading.Tasks; |
||||
|
using System.Data; |
||||
|
using System.IO; |
||||
|
using System.Data.Common; |
||||
|
using System.Windows.Media.Animation; |
||||
|
using System.Data.SQLite; |
||||
|
using System.Windows.Shapes; |
||||
|
using System.Drawing; |
||||
|
|
||||
|
|
||||
|
namespace SunlightCentralizedControlManagement_SCCM_.UserClass |
||||
|
{ |
||||
|
public class SqliteHelper |
||||
|
{ |
||||
|
|
||||
|
public class SQLiteHelper |
||||
|
{ |
||||
|
#region 字段
|
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 事务的基类
|
||||
|
/// </summary>
|
||||
|
private DbTransaction DBtrans; |
||||
|
/// <summary>
|
||||
|
/// 使用静态变量字典解决多线程实例本类,实现一个数据库对应一个clslock
|
||||
|
/// </summary>
|
||||
|
private static readonly Dictionary<string, ClsLock> RWL = new Dictionary<string, ClsLock>(); |
||||
|
/// <summary>
|
||||
|
/// 数据库地址
|
||||
|
/// </summary>
|
||||
|
private readonly string mdataFile; |
||||
|
/// <summary>
|
||||
|
/// 数据库密码
|
||||
|
/// </summary>
|
||||
|
private readonly string mPassWord; |
||||
|
private readonly string LockName = null; |
||||
|
/// <summary>
|
||||
|
/// 数据库连接定义
|
||||
|
/// </summary>
|
||||
|
private SQLiteConnection mConn; |
||||
|
|
||||
|
#endregion
|
||||
|
|
||||
|
#region 构造函数
|
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 根据数据库地址初始化
|
||||
|
/// </summary>
|
||||
|
/// <param name="dataFile">数据库地址</param>
|
||||
|
public SQLiteHelper(string dataFile) |
||||
|
{ |
||||
|
this.mdataFile = dataFile ?? throw new ArgumentNullException("dataFile=null"); |
||||
|
//this.mdataFile = AppDomain.CurrentDomain.BaseDirectory + dataFile;
|
||||
|
this.mdataFile = dataFile; |
||||
|
if (!RWL.ContainsKey(dataFile)) |
||||
|
{ |
||||
|
LockName = dataFile; |
||||
|
RWL.Add(dataFile, new ClsLock()); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 使用密码打开数据库
|
||||
|
/// </summary>
|
||||
|
/// <param name="dataFile">数据库地址</param>
|
||||
|
/// <param name="PassWord">数据库密码</param>
|
||||
|
public SQLiteHelper(string dataFile, string PassWord) |
||||
|
{ |
||||
|
this.mdataFile = dataFile ?? throw new ArgumentNullException("dataFile is null"); |
||||
|
this.mPassWord = PassWord ?? throw new ArgumentNullException("PassWord is null"); |
||||
|
//this.mdataFile = AppDomain.CurrentDomain.BaseDirectory + dataFile;
|
||||
|
this.mdataFile = dataFile; |
||||
|
if (!RWL.ContainsKey(dataFile)) |
||||
|
{ |
||||
|
LockName = dataFile; |
||||
|
RWL.Add(dataFile, new ClsLock()); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
#endregion
|
||||
|
|
||||
|
#region 打开/关闭 数据库
|
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 打开 SQLiteManager 使用的数据库连接
|
||||
|
/// </summary>
|
||||
|
public void Open() |
||||
|
{ |
||||
|
if (string.IsNullOrWhiteSpace(mPassWord)) |
||||
|
{ |
||||
|
mConn = OpenConnection(this.mdataFile); |
||||
|
} |
||||
|
else |
||||
|
{ |
||||
|
mConn = OpenConnection(this.mdataFile, mPassWord); |
||||
|
} |
||||
|
Console.WriteLine("The database was opened successfully"); |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 关闭连接
|
||||
|
/// </summary>
|
||||
|
public void Close() |
||||
|
{ |
||||
|
if (this.mConn != null) |
||||
|
{ |
||||
|
try |
||||
|
{ |
||||
|
this.mConn.Close(); |
||||
|
if (RWL.ContainsKey(LockName)) |
||||
|
{ |
||||
|
RWL.Remove(LockName); |
||||
|
} |
||||
|
} |
||||
|
catch |
||||
|
{ |
||||
|
Console.WriteLine("Shutdown failed"); |
||||
|
} |
||||
|
} |
||||
|
Console.WriteLine("The database was shut down successfully"); |
||||
|
} |
||||
|
|
||||
|
#endregion
|
||||
|
|
||||
|
#region 事务
|
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 开始事务
|
||||
|
/// </summary>
|
||||
|
public void BeginTrain() |
||||
|
{ |
||||
|
EnsureConnection(); |
||||
|
DBtrans = mConn.BeginTransaction(); |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 提交事务
|
||||
|
/// </summary>
|
||||
|
public void DBCommit() |
||||
|
{ |
||||
|
try |
||||
|
{ |
||||
|
DBtrans.Commit(); |
||||
|
} |
||||
|
catch (Exception) |
||||
|
{ |
||||
|
DBtrans.Rollback(); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
#endregion
|
||||
|
|
||||
|
#region 工具
|
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 打开一个SQLite数据库文件,如果文件不存在,则创建(无密码)
|
||||
|
/// </summary>
|
||||
|
/// <param name="dataFile"></param>
|
||||
|
/// <returns>SQLiteConnection 类</returns>
|
||||
|
private SQLiteConnection OpenConnection(string dataFile) |
||||
|
{ |
||||
|
if (dataFile == null) |
||||
|
{ |
||||
|
throw new ArgumentNullException("dataFiledataFile=null"); |
||||
|
} |
||||
|
if (!File.Exists(dataFile)) |
||||
|
{ |
||||
|
SQLiteConnection.CreateFile(dataFile); |
||||
|
} |
||||
|
SQLiteConnection conn = new SQLiteConnection(); |
||||
|
SQLiteConnectionStringBuilder conStr = new SQLiteConnectionStringBuilder |
||||
|
{ |
||||
|
DataSource = dataFile |
||||
|
}; |
||||
|
conn.ConnectionString = conStr.ToString(); |
||||
|
conn.Open(); |
||||
|
return conn; |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 打开一个SQLite数据库文件,如果文件不存在,则创建(有密码)
|
||||
|
/// </summary>
|
||||
|
/// <param name="dataFile"></param>
|
||||
|
/// <param name="Password"></param>
|
||||
|
/// <returns>SQLiteConnection 类</returns>
|
||||
|
private SQLiteConnection OpenConnection(string dataFile, string Password) |
||||
|
{ |
||||
|
if (dataFile == null) |
||||
|
{ |
||||
|
throw new ArgumentNullException("dataFile=null"); |
||||
|
} |
||||
|
if (!File.Exists(Convert.ToString(dataFile))) |
||||
|
{ |
||||
|
SQLiteConnection.CreateFile(dataFile); |
||||
|
} |
||||
|
try |
||||
|
{ |
||||
|
SQLiteConnection conn = new SQLiteConnection(); |
||||
|
SQLiteConnectionStringBuilder conStr = new SQLiteConnectionStringBuilder |
||||
|
{ |
||||
|
DataSource = dataFile, |
||||
|
Password = Password |
||||
|
}; |
||||
|
conn.ConnectionString = conStr.ToString(); |
||||
|
conn.Open(); |
||||
|
return conn; |
||||
|
} |
||||
|
catch (Exception) |
||||
|
{ |
||||
|
return null; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 读取 或 设置 SQLiteManager 使用的数据库连接
|
||||
|
/// </summary>
|
||||
|
public SQLiteConnection Connection |
||||
|
{ |
||||
|
get |
||||
|
{ |
||||
|
return mConn; |
||||
|
} |
||||
|
private set |
||||
|
{ |
||||
|
mConn = value ?? throw new ArgumentNullException(); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 确保数据库是连接状态
|
||||
|
/// </summary>
|
||||
|
/// <exception cref="Exception"></exception>
|
||||
|
protected void EnsureConnection() |
||||
|
{ |
||||
|
if (this.mConn == null) |
||||
|
{ |
||||
|
throw new Exception("SQLiteManager.Connection=null"); |
||||
|
} |
||||
|
if (mConn.State != ConnectionState.Open) |
||||
|
{ |
||||
|
mConn.Open(); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 获取数据库文件的路径
|
||||
|
/// </summary>
|
||||
|
/// <returns></returns>
|
||||
|
public string GetDataFile() |
||||
|
{ |
||||
|
return this.mdataFile; |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 判断表 table 是否存在
|
||||
|
/// </summary>
|
||||
|
/// <param name="table"></param>
|
||||
|
/// <returns>存在返回true,否则返回false</returns>
|
||||
|
public bool TableExists(string table) |
||||
|
{ |
||||
|
if (table == null) |
||||
|
{ |
||||
|
throw new ArgumentNullException("table=null"); |
||||
|
} |
||||
|
EnsureConnection(); |
||||
|
SQLiteDataReader reader = ExecuteReader("SELECT count(*) as c FROM sqlite_master WHERE type='table' AND name=@tableName ", new SQLiteParameter[] { new SQLiteParameter("tableName", table) }); |
||||
|
if (reader == null) |
||||
|
{ |
||||
|
return false; |
||||
|
} |
||||
|
reader.Read(); |
||||
|
int c = reader.GetInt32(0); |
||||
|
reader.Close(); |
||||
|
reader.Dispose(); |
||||
|
//return false;
|
||||
|
return c == 1; |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// VACUUM 命令(通过复制主数据库中的内容到一个临时数据库文件,然后清空主数据库,并从副本中重新载入原始的数据库文件)
|
||||
|
/// </summary>
|
||||
|
/// <returns></returns>
|
||||
|
public bool Vacuum() |
||||
|
{ |
||||
|
try |
||||
|
{ |
||||
|
using (SQLiteCommand Command = new SQLiteCommand("VACUUM", Connection)) |
||||
|
{ |
||||
|
Command.ExecuteNonQuery(); |
||||
|
} |
||||
|
return true; |
||||
|
} |
||||
|
catch (System.Data.SQLite.SQLiteException) |
||||
|
{ |
||||
|
return false; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
#endregion
|
||||
|
|
||||
|
#region 执行SQL
|
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 执行SQL, 并返回 SQLiteDataReader 对象结果
|
||||
|
/// </summary>
|
||||
|
/// <param name="sql"></param>
|
||||
|
/// <param name="paramArr">null 表示无参数</param>
|
||||
|
/// <returns></returns>
|
||||
|
public SQLiteDataReader ExecuteReader(string sql, SQLiteParameter[] paramArr) |
||||
|
{ |
||||
|
if (sql == null) |
||||
|
{ |
||||
|
throw new ArgumentNullException("sql=null"); |
||||
|
} |
||||
|
EnsureConnection(); |
||||
|
using (RWL[LockName].Read()) |
||||
|
{ |
||||
|
using (SQLiteCommand cmd = new SQLiteCommand(sql, Connection)) |
||||
|
{ |
||||
|
if (paramArr != null) |
||||
|
{ |
||||
|
cmd.Parameters.AddRange(paramArr); |
||||
|
} |
||||
|
try |
||||
|
{ |
||||
|
SQLiteDataReader reader = cmd.ExecuteReader(); |
||||
|
cmd.Parameters.Clear(); |
||||
|
return reader; |
||||
|
} |
||||
|
catch (Exception) |
||||
|
{ |
||||
|
return null; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 执行查询,并返回dataset对象
|
||||
|
/// </summary>
|
||||
|
/// <param name="sql">SQL查询语句</param>
|
||||
|
/// <param name="paramArr">参数数组</param>
|
||||
|
/// <returns></returns>
|
||||
|
public DataSet ExecuteDataSet(string sql, SQLiteParameter[] paramArr) |
||||
|
{ |
||||
|
if (sql == null) |
||||
|
{ |
||||
|
throw new ArgumentNullException("sql=null"); |
||||
|
} |
||||
|
this.EnsureConnection(); |
||||
|
using (RWL[LockName].Read()) |
||||
|
{ |
||||
|
using (SQLiteCommand cmd = new SQLiteCommand(sql, this.Connection)) |
||||
|
{ |
||||
|
if (paramArr != null) |
||||
|
{ |
||||
|
cmd.Parameters.AddRange(paramArr); |
||||
|
} |
||||
|
try |
||||
|
{ |
||||
|
SQLiteDataAdapter da = new SQLiteDataAdapter(); |
||||
|
DataSet ds = new DataSet(); |
||||
|
da.SelectCommand = cmd; |
||||
|
da.Fill(ds); |
||||
|
cmd.Parameters.Clear(); |
||||
|
da.Dispose(); |
||||
|
return ds; |
||||
|
} |
||||
|
catch (Exception) |
||||
|
{ |
||||
|
return null; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 执行SQL查询,并返回dataset对象。
|
||||
|
/// </summary>
|
||||
|
/// <param name="strTable">映射源表的名称</param>
|
||||
|
/// <param name="sql">SQL语句</param>
|
||||
|
/// <param name="paramArr">SQL参数数组</param>
|
||||
|
/// <returns></returns>
|
||||
|
public DataSet ExecuteDataSet(string strTable, string sql, SQLiteParameter[] paramArr) |
||||
|
{ |
||||
|
if (sql == null) |
||||
|
{ |
||||
|
throw new ArgumentNullException("sql=null"); |
||||
|
} |
||||
|
this.EnsureConnection(); |
||||
|
using (RWL[LockName].Read()) |
||||
|
{ |
||||
|
using (SQLiteCommand cmd = new SQLiteCommand(sql, this.Connection)) |
||||
|
{ |
||||
|
if (paramArr != null) |
||||
|
{ |
||||
|
cmd.Parameters.AddRange(paramArr); |
||||
|
} |
||||
|
try |
||||
|
{ |
||||
|
SQLiteDataAdapter da = new SQLiteDataAdapter(); |
||||
|
DataSet ds = new DataSet(); |
||||
|
da.SelectCommand = cmd; |
||||
|
da.Fill(ds, strTable); |
||||
|
cmd.Parameters.Clear(); |
||||
|
da.Dispose(); |
||||
|
return ds; |
||||
|
} |
||||
|
catch (Exception) |
||||
|
{ |
||||
|
return null; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 执行SQL,返回受影响的行数,可用于执行表创建语句,paramArr == null 表示无参数
|
||||
|
/// </summary>
|
||||
|
/// <param name="sql"></param>
|
||||
|
/// <returns></returns>
|
||||
|
public int ExecuteNonQuery(string sql, SQLiteParameter[] paramArr) |
||||
|
{ |
||||
|
if (sql == null) |
||||
|
{ |
||||
|
throw new ArgumentNullException("sql=null"); |
||||
|
} |
||||
|
this.EnsureConnection(); |
||||
|
using (RWL[LockName].Read()) |
||||
|
{ |
||||
|
try |
||||
|
{ |
||||
|
using (SQLiteCommand cmd = new SQLiteCommand(sql, Connection)) |
||||
|
{ |
||||
|
if (paramArr != null) |
||||
|
{ |
||||
|
foreach (SQLiteParameter p in paramArr) |
||||
|
{ |
||||
|
cmd.Parameters.Add(p); |
||||
|
} |
||||
|
} |
||||
|
int c = cmd.ExecuteNonQuery(); |
||||
|
cmd.Parameters.Clear(); |
||||
|
return c; |
||||
|
} |
||||
|
} |
||||
|
catch (SQLiteException) |
||||
|
{ |
||||
|
return 0; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 执行SQL,返回结果集第一行,如果结果集为空,那么返回空 List(List.Count=0),
|
||||
|
/// rowWrapper = null 时,使用 WrapRowToDictionary
|
||||
|
/// </summary>
|
||||
|
/// <param name="sql"></param>
|
||||
|
/// <param name="paramArr"></param>
|
||||
|
/// <returns></returns>
|
||||
|
public object ExecuteScalar(string sql, SQLiteParameter[] paramArr) |
||||
|
{ |
||||
|
if (sql == null) |
||||
|
{ |
||||
|
throw new ArgumentNullException("sql=null"); |
||||
|
} |
||||
|
this.EnsureConnection(); |
||||
|
using (RWL[LockName].Read()) |
||||
|
{ |
||||
|
using (SQLiteCommand cmd = new SQLiteCommand(sql, Connection)) |
||||
|
{ |
||||
|
if (paramArr != null) |
||||
|
{ |
||||
|
cmd.Parameters.AddRange(paramArr); |
||||
|
} |
||||
|
try |
||||
|
{ |
||||
|
object reader = cmd.ExecuteScalar(); |
||||
|
cmd.Parameters.Clear(); |
||||
|
cmd.Dispose(); |
||||
|
return reader; |
||||
|
} |
||||
|
catch (Exception) |
||||
|
{ |
||||
|
return null; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 查询一行记录,无结果时返回 null,conditionCol = null 时将忽略条件,直接执行 select * from table
|
||||
|
/// </summary>
|
||||
|
/// <param name="table">表名</param>
|
||||
|
/// <param name="conditionCol"></param>
|
||||
|
/// <param name="conditionVal"></param>
|
||||
|
/// <returns></returns>
|
||||
|
public object QueryOne(string table, string conditionCol, object conditionVal) |
||||
|
{ |
||||
|
if (table == null) |
||||
|
{ |
||||
|
throw new ArgumentNullException("table=null"); |
||||
|
} |
||||
|
this.EnsureConnection(); |
||||
|
string sql = "select * from " + table; |
||||
|
if (conditionCol != null) |
||||
|
{ |
||||
|
sql += " where " + conditionCol + "=@" + conditionCol; |
||||
|
} |
||||
|
object result = ExecuteScalar(sql, new SQLiteParameter[] { new SQLiteParameter(conditionCol, conditionVal) }); |
||||
|
return result; |
||||
|
} |
||||
|
|
||||
|
#endregion
|
||||
|
|
||||
|
#region 增 删 改
|
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 执行 insert into 语句
|
||||
|
/// </summary>
|
||||
|
/// <param name="table"></param>
|
||||
|
/// <param name="entity"></param>
|
||||
|
/// <returns></returns>
|
||||
|
public int InsertData(string table, Dictionary<string, object> entity) |
||||
|
{ |
||||
|
if (table == null) |
||||
|
{ |
||||
|
throw new ArgumentNullException("table=null"); |
||||
|
} |
||||
|
this.EnsureConnection(); |
||||
|
string sql = BuildInsert(table, entity); |
||||
|
return this.ExecuteNonQuery(sql, BuildParamArray(entity)); |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 执行 update 语句,注意:如果 where = null,那么 whereParams 也为 null,
|
||||
|
/// </summary>
|
||||
|
/// <param name="table">表名</param>
|
||||
|
/// <param name="entity">要修改的列名和列名的值</param>
|
||||
|
/// <param name="where">查找符合条件的列</param>
|
||||
|
/// <param name="whereParams">where条件中参数的值</param>
|
||||
|
/// <returns></returns>
|
||||
|
public int Update(string table, Dictionary<string, object> entity, string where, SQLiteParameter[] whereParams) |
||||
|
{ |
||||
|
if (table == null) |
||||
|
{ |
||||
|
throw new ArgumentNullException("table=null"); |
||||
|
} |
||||
|
this.EnsureConnection(); |
||||
|
string sql = BuildUpdate(table, entity); |
||||
|
SQLiteParameter[] parameter = BuildParamArray(entity); |
||||
|
if (where != null) |
||||
|
{ |
||||
|
sql += " where " + where; |
||||
|
if (whereParams != null) |
||||
|
{ |
||||
|
SQLiteParameter[] newArr = new SQLiteParameter[(parameter.Length + whereParams.Length)]; |
||||
|
Array.Copy(parameter, newArr, parameter.Length); |
||||
|
Array.Copy(whereParams, 0, newArr, parameter.Length, whereParams.Length); |
||||
|
parameter = newArr; |
||||
|
} |
||||
|
} |
||||
|
return this.ExecuteNonQuery(sql, parameter); |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 执行 delete from table 语句,where不必包含'where'关键字,where = null 时将忽略 whereParams
|
||||
|
/// </summary>
|
||||
|
/// <param name="table"></param>
|
||||
|
/// <param name="where"></param>
|
||||
|
/// <param name="whereParams"></param>
|
||||
|
/// <returns></returns>
|
||||
|
public int Delete(string table, string where, SQLiteParameter[] whereParams) |
||||
|
{ |
||||
|
if (table == null) |
||||
|
{ |
||||
|
throw new ArgumentNullException("table=null"); |
||||
|
} |
||||
|
this.EnsureConnection(); |
||||
|
string sql = "delete from " + table + " "; |
||||
|
if (where != null) |
||||
|
{ |
||||
|
sql += "where " + where; |
||||
|
} |
||||
|
return ExecuteNonQuery(sql, whereParams); |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 将 Dictionary 类型数据 转换为 SQLiteParameter[] 类型
|
||||
|
/// </summary>
|
||||
|
/// <param name="entity"></param>
|
||||
|
/// <returns></returns>
|
||||
|
private SQLiteParameter[] BuildParamArray(Dictionary<string, object> entity) |
||||
|
{ |
||||
|
List<SQLiteParameter> list = new List<SQLiteParameter>(); |
||||
|
foreach (string key in entity.Keys) |
||||
|
{ |
||||
|
list.Add(new SQLiteParameter(key, entity[key])); |
||||
|
} |
||||
|
if (list.Count == 0) |
||||
|
{ |
||||
|
return null; |
||||
|
} |
||||
|
return list.ToArray(); |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 将 Dictionary 类型数据 转换为 插入数据 的 SQL语句
|
||||
|
/// </summary>
|
||||
|
/// <param name="table">表名</param>
|
||||
|
/// <param name="entity">字典</param>
|
||||
|
/// <returns></returns>
|
||||
|
private string BuildInsert(string table, Dictionary<string, object> entity) |
||||
|
{ |
||||
|
StringBuilder buf = new StringBuilder(); |
||||
|
buf.Append("insert into ").Append(table); |
||||
|
buf.Append(" ("); |
||||
|
foreach (string key in entity.Keys) |
||||
|
{ |
||||
|
buf.Append(key).Append(","); |
||||
|
} |
||||
|
buf.Remove(buf.Length - 1, 1); // 移除最后一个,
|
||||
|
buf.Append(") "); |
||||
|
buf.Append("values("); |
||||
|
foreach (string key in entity.Keys) |
||||
|
{ |
||||
|
buf.Append("@").Append(key).Append(","); // 创建一个参数
|
||||
|
} |
||||
|
buf.Remove(buf.Length - 1, 1); |
||||
|
buf.Append(") "); |
||||
|
|
||||
|
return buf.ToString(); |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 将 Dictionary 类型数据 转换为 修改数据 的 SQL语句
|
||||
|
/// </summary>
|
||||
|
/// <param name="table">表名</param>
|
||||
|
/// <param name="entity">字典</param>
|
||||
|
/// <returns></returns>
|
||||
|
private string BuildUpdate(string table, Dictionary<string, object> entity) |
||||
|
{ |
||||
|
StringBuilder buf = new StringBuilder(); |
||||
|
buf.Append("update ").Append(table).Append(" set "); |
||||
|
foreach (string key in entity.Keys) |
||||
|
{ |
||||
|
buf.Append(key).Append("=").Append("@").Append(key).Append(","); |
||||
|
} |
||||
|
buf.Remove(buf.Length - 1, 1); |
||||
|
buf.Append(" "); |
||||
|
return buf.ToString(); |
||||
|
} |
||||
|
|
||||
|
/// <summary>
|
||||
|
/// 将 DataTable 转换为 Dictionary 类型数据
|
||||
|
/// </summary>
|
||||
|
public Dictionary<string, object> DataTableToDictionary(DataTable dataTable) |
||||
|
{ |
||||
|
Dictionary<string, object> result = new Dictionary<string, object>(); |
||||
|
if (dataTable != null) |
||||
|
{ |
||||
|
foreach (DataRow dataRow in dataTable.Rows) |
||||
|
{ |
||||
|
foreach (DataColumn dataColumn in dataTable.Columns) |
||||
|
{ |
||||
|
result.Add(dataColumn.ColumnName, dataRow[dataColumn].ToString()); |
||||
|
//result = Console.WriteLine(dataRow[dataColumn].ToString());
|
||||
|
//result.Add(dataColumn.ColumnName, dataRow[dataColumn].ToString())(new RepeatDictionaryComparer());
|
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
else |
||||
|
{ |
||||
|
result = null; |
||||
|
} |
||||
|
return result; |
||||
|
} |
||||
|
|
||||
|
} |
||||
|
#endregion
|
||||
|
} |
||||
|
} |
@ -0,0 +1,36 @@ |
|||||
|
<UserControl x:Class="SunlightCentralizedControlManagement_SCCM_.View.RoilingTextBlock" |
||||
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" |
||||
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" |
||||
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" |
||||
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008" |
||||
|
xmlns:local="clr-namespace:SunlightCentralizedControlManagement_SCCM_.View" |
||||
|
mc:Ignorable="d" |
||||
|
DataContext="{Binding RelativeSource={RelativeSource Self}}" |
||||
|
d:DesignWidth="300" Height="30" > |
||||
|
<UserControl.Template> |
||||
|
<ControlTemplate TargetType="UserControl"> |
||||
|
<Border BorderBrush="White" |
||||
|
BorderThickness="1" |
||||
|
Padding="2" |
||||
|
Background="White"> |
||||
|
<Canvas x:Name="innerCanvas" |
||||
|
Width="Auto" |
||||
|
Height="Auto" |
||||
|
Background="White" |
||||
|
ClipToBounds="True"> |
||||
|
<TextBlock x:Name="textBlock" |
||||
|
Width="Auto" |
||||
|
Height="Auto" |
||||
|
ClipToBounds="True" |
||||
|
TextAlignment="Center" |
||||
|
Canvas.Left="{Binding Left,Mode=TwoWay}" |
||||
|
Canvas.Top="{Binding Top,Mode=TwoWay}" |
||||
|
FontSize="{Binding FontSize,Mode=TwoWay}" |
||||
|
Text="{Binding Text,Mode=TwoWay}" |
||||
|
Foreground="{Binding Foreground,Mode=TwoWay}"/> |
||||
|
</Canvas> |
||||
|
|
||||
|
</Border> |
||||
|
</ControlTemplate> |
||||
|
</UserControl.Template> |
||||
|
</UserControl> |
@ -0,0 +1,126 @@ |
|||||
|
using System; |
||||
|
using System.Collections.Generic; |
||||
|
using System.Linq; |
||||
|
using System.Text; |
||||
|
using System.Threading.Tasks; |
||||
|
using System.Windows; |
||||
|
using System.Windows.Controls; |
||||
|
using System.Windows.Data; |
||||
|
using System.Windows.Documents; |
||||
|
using System.Windows.Input; |
||||
|
using System.Windows.Media; |
||||
|
using System.Windows.Media.Imaging; |
||||
|
using System.Windows.Navigation; |
||||
|
using System.Windows.Shapes; |
||||
|
using System.Windows.Threading; |
||||
|
|
||||
|
namespace SunlightCentralizedControlManagement_SCCM_.View |
||||
|
{ |
||||
|
/// <summary>
|
||||
|
/// RoilingTextBlock.xaml 的交互逻辑
|
||||
|
/// </summary>
|
||||
|
public partial class RoilingTextBlock : UserControl |
||||
|
{ |
||||
|
private bool canRoll = false; |
||||
|
private readonly double rollingInterval = 0.5;//每一步的偏移量
|
||||
|
private double offset=6;//最大的偏移量
|
||||
|
private TextBlock currentTextBlock = null; |
||||
|
private DispatcherTimer currentTimer = null; |
||||
|
public RoilingTextBlock() |
||||
|
{ |
||||
|
InitializeComponent(); |
||||
|
Loaded += RoilingTextBlock_Loaded; |
||||
|
} |
||||
|
|
||||
|
void RoilingTextBlock_Loaded(object sender, RoutedEventArgs e) |
||||
|
{ |
||||
|
if (this.currentTextBlock != null) |
||||
|
{ |
||||
|
canRoll = this.currentTextBlock.ActualWidth > this.ActualWidth; |
||||
|
} |
||||
|
currentTimer = new System.Windows.Threading.DispatcherTimer(); |
||||
|
currentTimer.Interval = TimeSpan.FromMilliseconds(100); |
||||
|
currentTimer.Tick += new EventHandler(currentTimer_Tick); |
||||
|
currentTimer.Start(); |
||||
|
} |
||||
|
|
||||
|
public override void OnApplyTemplate() |
||||
|
{ |
||||
|
try |
||||
|
{ |
||||
|
base.OnApplyTemplate(); |
||||
|
currentTextBlock = this.GetTemplateChild("textBlock") as TextBlock; |
||||
|
} |
||||
|
catch (Exception) |
||||
|
{ |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
void currentTimer_Tick(object sender, EventArgs e) |
||||
|
{ |
||||
|
if (this.currentTextBlock != null && canRoll) |
||||
|
{ |
||||
|
if (Math.Abs(Left) <= this.currentTextBlock.ActualWidth-offset) |
||||
|
{ |
||||
|
Left-=rollingInterval; |
||||
|
} |
||||
|
else |
||||
|
{ |
||||
|
Left = this.ActualHeight; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
#region Dependency Properties
|
||||
|
public static DependencyProperty TextProperty = |
||||
|
DependencyProperty.Register("Text", typeof(string), typeof(RoilingTextBlock), |
||||
|
new PropertyMetadata("")); |
||||
|
|
||||
|
public static new DependencyProperty FontSizeProperty = |
||||
|
DependencyProperty.Register("FontSize", typeof(double), typeof(RoilingTextBlock), |
||||
|
new PropertyMetadata(14D)); |
||||
|
|
||||
|
public static new readonly DependencyProperty ForegroundProperty = |
||||
|
DependencyProperty.Register("Foreground", typeof(Brush), typeof(RoilingTextBlock), new FrameworkPropertyMetadata(Brushes.Green)); |
||||
|
|
||||
|
public static DependencyProperty LeftProperty = |
||||
|
DependencyProperty.Register("Left", typeof(double), typeof(RoilingTextBlock), new PropertyMetadata(0D)); |
||||
|
|
||||
|
public static DependencyProperty TopProperty = |
||||
|
DependencyProperty.Register("Top", typeof(double), typeof(RoilingTextBlock), new PropertyMetadata(0D)); |
||||
|
|
||||
|
#endregion
|
||||
|
|
||||
|
#region Public Variables
|
||||
|
public string Text |
||||
|
{ |
||||
|
get { return (string)GetValue(TextProperty); } |
||||
|
set { SetValue(TextProperty, value); } |
||||
|
} |
||||
|
|
||||
|
public new double FontSize |
||||
|
{ |
||||
|
get { return (double)GetValue(FontSizeProperty); } |
||||
|
set { SetValue(FontSizeProperty, value); } |
||||
|
} |
||||
|
|
||||
|
public new Brush Foreground |
||||
|
{ |
||||
|
get { return (Brush)GetValue(ForegroundProperty); } |
||||
|
set { SetValue(ForegroundProperty, value); } |
||||
|
} |
||||
|
|
||||
|
public double Left |
||||
|
{ |
||||
|
get { return (double)GetValue(LeftProperty); } |
||||
|
set { SetValue(LeftProperty, value); } |
||||
|
} |
||||
|
|
||||
|
public double Top |
||||
|
{ |
||||
|
get { return (double)GetValue(TopProperty); } |
||||
|
set { SetValue(TopProperty, value); } |
||||
|
} |
||||
|
#endregion
|
||||
|
} |
||||
|
} |
Loading…
Reference in new issue