C# in VS
1. DllImport是System.Runtime.InteropServices命名空间下与与非托管相关的一个属性类,负责导出从非托管的dll中导出函数信息,导出的函数在声明时必须有extern修饰;copy的dll文件可以放置在System32目录(在import时可以不写路径)。
2.Marshal类可以实现托管和非托管的相互转换,它的命名空间也是System.Runtime.InteropServices,已用过Marshal.PtrToStringAnsi方法。
3.鼠标钩子WH_MOUSE_LL和WH_MOUSE的区别:
前者可以截获所有模块的鼠标事件,后者只能截获监控钩子所在模块的鼠标事件。全局hook应在一个独立的dll中。
4.解决方案solution里有多个projects,其中一个project用到另一个project里的类,需要在此project中右键add reference,再用using加命名空间的形式添加对类的引用;需要编译成DLL的project,其property的输出类型应为Class Library。
5.往数据库的表中插入新行。
//方法一:用DataAdapter方法,优点:不用写insert语句且不用关心values后边的各字段的形式,如要不要加单引号之类的;缺点:插入一条记录的效率不及写单纯insert语句 SqlConnection conn = ConnectDB(server, db); string sql = "select * from " + tableName; SqlDataAdapter da = new SqlDataAdapter(sql, conn); SqlCommandBuilder scb = new SqlCommandBuilder(da);//SqlCommandBuilder根据insertCommand构造 updatecommand和deletecommand DataTable dt = new DataTable(); exeTable(conn, dt, sql); DataRow dr = dt.NewRow(); dr.ItemArray = columnValues; dt.Rows.Add(dr); da.Update(dt); conn.Close(); // 方法二:单纯写insert语句插入一条记录,优点:单条数据插入效率高 缺点:需要注意sql语句的构造和sql语句中参数的类型 string sql = "insert into 表名 values(" + 值1+ "," + 值2+ ",'" + 值3+ "',"+ 值4+ "," + 值5+ "," + 值6+",@参数1,'" + 值7+ "','"+ 值8+ "')"; SqlParameter param = new System.Data.SqlClient.SqlParameter("@参数1", SqlDbType.Image); param.Value = 值9; SqlConnection conn = sqlHelper.ConnectDB(); SqlCommand cmd = new System.Data.SqlClient.SqlCommand(sql, conn); if (param != null) cmd.Parameters.Add(param); cmd.ExecuteNonQuery(); conn.Close(); //方法三:插入大批量数据时用SqlBulkCopy,单条记录插入效率较慢 DataTable dt = new DataTable(); dt.Columns.Add("列名1", typeof(string)); dt.Columns.Add("列名2", typeof(byte[])); DataRow dr = dt.NewRow(); dr["列名1"] = 值1; dr["列名2"] = 值2; dt.Rows.Add(dr); dr = dt.NewRow(); dr["列名1"] = 值3; dr["列名2"] = 值4; dt.Rows.Add(dr); SqlBulkCopy bulk = new System.Data.SqlClient.SqlBulkCopy(conn); bulk.DestinationTableName=目标表名; bulk.BatchSize=dt.Rows.Count; bulk.ColumnMappings.Add("列名1",目标列名1); bulk.ColumnMappings.Add("列名2",目标列名2); bulk.WriteToServer(dt); bulk.Close(); conn.Close();
6.更新数据表某一行的字段值
public static void UpdateFieldValue(string tableName,int rowIndex,Dictionary<string,object> dic_column_value) { SqlConnection conn = ConnectDB(); string sql = "select * from " + tableName; SqlDataAdapter da = new SqlDataAdapter(sql, conn); SqlCommandBuilder scb = new SqlCommandBuilder(da); da.UpdateCommand = scb.GetUpdateCommand(); DataSet dataset = new DataSet(); da.Fill(dataset,tableName); //更新字段值 foreach(KeyValuePair<string,object> kvp in dic_column_value) { dataset.Tables[].Rows[rowIndex][kvp.Key] = kvp.Value; } da.Update(dataset,tableName); conn.Close(); }
7.修改文本文件某一行数据的两种方法。
1)File类
//找到setLocation string[] ary = File.ReadAllLines(path, Encoding.Default); ary = ary.Select(t => t.Trim().StartsWith("setLocation") ? setLocation : t.Trim()).ToArray(); File.WriteAllLines(path, ary, Encoding.Default);
2)StreamReader类
string text = ""; using (StreamReader reader = new StreamReader(path, Encoding.Default)) { string line = reader.ReadLine(); while (line != null) { //如果这一行以setLocation开始,就替换原来的信息 if (line.StartsWith("setLocation")) { line = setLocation; } text += line + "\r\n"; line = reader.ReadLine(); } reader.Close(); reader.Dispose(); } //写入流,更新数据 using (StreamWriter writer = new StreamWriter(path)) { writer.Write(text); writer.Close(); writer.Dispose(); }
8.查询DataTable
DataTable dt_New = sourceTable.Clone(); DataRow[] drs = sourceTable.Select(filter); foreach (DataRow dr in drs) { dt_New.Rows.Add(dr.ItemArray); } return dt_New;
9.linq取DataTable某一列数据返回给一个List<int>。
var list =dt.AsEnumerable().Select<DataRow, int>(x => Convert.ToInt32(x["列名"])).ToList<int>();
10.取dictionary<key,double>中value按升序排列的第一个key值。
var minValueKey=(from d in dic orderby d.Value ascending select d.Key).First()
11.利用sqlserver 提供的bcp.exe插入数据。
class bcpHelper { public static StreamWriter SW_log { get; set; } static string bcpExePath = Environment.GetEnvironmentVariable("programfiles")+ @"\Microsoft SQL Server\100\Tools\Binn\bcp.exe"; public static void BatchInsertProcess(string dbName,string svName,string sourceFile,string targetTable, string errorFile,string outBcpFile) { //-c则要求要插入的文件编码为ascii编码,-w则为Unicode string args = "["+dbName+"]" + ".." +"["+ targetTable+"]" + " in \"" + sourceFile + "\"" + " -S " + svName + " -T -w -t \",\" -e \""+errorFile+"\" -o \""+outBcpFile+"\""; shellHelper.executeShellCmd(bcpExePath, args); //判断bcp是否成功 FileInfo fi = new FileInfo(errorFile); ) { Console.WriteLine("Error:Fail to process bcp!"); txtWriteHelper.AppendLog(SW_log, "Error:Fail to process bcp!"); } } }
12.Math中的取整方法
Floor:向下取整,只取整数部分;
Round:四舍六入,遇到五则取偶数;
Ceiling:向上取整,只要小数部分大于等于一,均往上加一。
随机推荐
- 如何在Python中实现这五类强大的概率分布
R编程语言已经成为统计分析中的事实标准.但在这篇文章中,我将告诉你在Python中实现统计学概念会是如此容易.我要使用Python实现一些离散和连续的概率分布.虽然我不会讨论这些分布的数学细节,但我会 ...
- Countries in War -POJ3114Tarjan缩点+SPFA
Countries in War Time Limit: 1000MS Memory Limit: 65536K Description In the year 2050, after differe ...
- django之DB操作
先来区分一下什么是一对一.多对多 一对一:子表从母表中选出一条数据一一对应,母表中选出来一条就少一条,子表不可以再选择母表中已被选择的那条数据: 一对多:子表从母表中选出一条数据一一对应,但母表的这条 ...
- What's the difference between <b> and <strong>, <i> and <em> in HTML/XHTML? When should you use each?
ref:http://stackoverflow.com/questions/271743/whats-the-difference-between-b-and-strong-i-and-em The ...
- mysql 导出批量导出表数据 (程序)
private static String driverName = "com.mysql.jdbc.Driver"; public static void main(String ...
- smarty模板引擎
1. 使用smarty 1.1 项目引入 // 3, 连接数据库,提取相关数据 $title = "Smarty模板引擎"; $content = "Smarty模 ...
- sql-按周输出每月的周日期范围
--日期参数,此处可以建立存储过程,接收月份,计算月开始结束时间或者直接接受开始与结束时间 declare @begDate datetime = '2014-06-01' declare @endD ...
- linux下与windows下的换行符
[原文有些许错误,已作了修改] 回车符号和换行符号产生背景 关于“回车”(carriage return)和“换行”(line feed)这两个概念的来历和区别.在计算机还没有出现之前,有一种叫做电传 ...
- html5上传图片
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- JavaScript中有关数字的精确计算
问题这样的: 37.5*5.5=206.08 (JS算出来是这样的一个结果,我四舍五入取两位小数) ,我先怀疑是四舍五入的问题,就直接用JS算了一个结果为:206.08499999999998 怎么会 ...