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:向上取整,只要小数部分大于等于一,均往上加一。
随机推荐
- 每天一点Android干货-Activity的生命周期
Activity Activity是这样一个程序组件,它为用户提供一个用于任务交互的画面. 一个应用程序通常由多个activity组成,它们彼此保持弱的绑定状态.典型的,当一个activity在一个应 ...
- 我的Android第二章
前言 之前有很多人遇到了关于内部类的问题[主要在android的学习之中会大量的使用到],内部类是什么,内部类怎么定义,内部类的分类,内部类的好处,内部类如何访问,这里我们来结合代码简单的理解一下 1 ...
- Mybatis框架基于映射文件和配置文件的方式,实现增删改查,可以打印日志信息
首先在lib下导入: 与打印日志信息有关的架包 log4j-1.2.16.jar mybatis架包:mybatis-3.1.1.jar 连接数据库的架包:mysql-connector-java-5 ...
- 【leetcode❤python】 189. Rotate Array
#-*- coding: UTF-8 -*-#由于题目要求不返回任何值,修改原始列表,#因此不能直接将新生成的结果赋值给nums,这样只是将变量指向新的列表,原列表并没有修改.#需要将新生成的结果赋予 ...
- ognl.OgnlException: target is null for setProperty(null, "emailTypeNo", [Ljava.lang.String;@1513fd0)
[com.opensymphony.xwork2.ognl.OgnlValueStack] - Error setting expression 'emaiTypeDto.emailTypeNo' w ...
- MVC开发模式之Servlet+jsp+javaBean
Servlet+jsp+JavaBean组合开发是一种MVC开发模式,控制器Controller采用Servlet.模型Model采用JavaBean.视图View采用JSP. 1.Web开发的请求- ...
- 在windows上搭建react-native的android环境
参考文档: http://facebook.github.io/react-native/docs/getting-started.html http://reactnative.cn/docs/0. ...
- es6还欠完善的地方
const的可变性 const用于声明常量. 什么是常量,声明后的值不可更改. 对于值类型,比如string,number等等.const声明确实有效. const str = "strin ...
- [bzoj1122][POI2008]账本BBB
1122: [POI2008]账本BBB Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 402 Solved: 202[Submit][Status ...
- ajax提交表单+前端验证小示例
<script src="http://css.jj.cn/js/jquery.js" type="text/javascript"></sc ...