SELECT INTO和INSERT INTO SELECT的区别

 

数据库中的数据复制备份

SELECT INTO:

形式:

  1. SELECT value1,value2,value3 INTO Table_2 FROM Table_1

Table_2表存在,报错:数据库中已存在名为 'Table_2' 的对象。

Table_2表不存在,自动创建表Table_2,成功导入数据

INSERT INTO SELECT:

形式:

  1. INSERT INTO Table_2 (v1,v2,v3) SELECT v4,v5,v6 FROM Table_1

Table_2表不存在,报错:对象名 'Table_2' 无效。

Table_2表存在:成功导入数据

类似aaa?a=1&b=2&c=3&d=4,如何将问号以后的数据变为键值对

 
  1. string result = "aaa?a=1&b=2&c=3&d=4";
  2. string[] array = result.Split('?');
  3. //string a = System.Web.HttpUtility.ParseQueryString(array[1]).Get("a");
  4. System.Collections.Specialized.NameValueCollection abcd = System.Web.HttpUtility.ParseQueryString(array[1]);
  5. string a = abcd.Get("a");
  6. string b = abcd.Get("b");
  7. string c = abcd.Get("c");
  8. string d = abcd.Get("d");

ParseQueryString的内部实现(字符串截取):

  1. int num = (s != null) ? s.Length : 0;
  2. System.Collections.Specialized.NameValueCollection a = new System.Collections.Specialized.NameValueCollection();
  3. for (int i = 0; i < num; i++)
  4. {
  5. int startIndex = i;
  6. int num4 = -1;
  7. while (i < num)
  8. {
  9. char ch = s[i];
  10. if (ch == '=')
  11. {
  12. if (num4 < 0)
  13. {
  14. num4 = i;
  15. }
  16. }
  17. else if (ch == '&')
  18. {
  19. break;
  20. }
  21. i++;
  22. }
  23. string str = null;
  24. string str2 = null;
  25. if (num4 >= 0)
  26. {
  27. str = s.Substring(startIndex, num4 - startIndex);
  28. str2 = s.Substring(num4 + 1, (i - num4) - 1);
  29. }
  30. else
  31. {
  32. str2 = s.Substring(startIndex, i - startIndex);
  33. }
  34. a.Add(str, str2);
  35. if ((i == (num - 1)) && (s[i] == '&'))
  36. {
  37. a.Add(null, string.Empty);
  38. }
  39. }

点击链接学习:膜拜高手

 

C# 获取一定区间的随即数 0、1两个值除随机数以外的取值方法(0、1两个值被取值的概率相等)

 

获取随机数

举例:0-9

  1. Random random = new Random();
  2. int j = random.Next(0, 9);

0、1两个值被取值的概率相等

  1. int a = Math.Abs(Guid.NewGuid().GetHashCode()) % 2;
  2. if (a == 0)
  3. {}
  4. else if(a==1)
  5. {}
  1. /// <summary>
  2. /// 获取等概率的小于最大数的非负随机数
  3. /// </summary>
  4. /// <param name="n">最大数</param>
  5. /// <returns></returns>
  6. public static int Estimate(int n)
  7. {
  8. return Math.Abs(Guid.NewGuid().GetHashCode()) % n;
  9. }
 

C# MD5 加密,解密

 

//生成cs文件

public class MD5Help
{
  ///MD5加密 
  public static string MD5Encrypt(string pToEncrypt, string sKey)
  {
  DESCryptoServiceProvider des = new DESCryptoServiceProvider();
  byte[] inputByteArray = Encoding.Default.GetBytes(pToEncrypt);
  des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
  des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
  MemoryStream ms = new MemoryStream();
  CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
  cs.Write(inputByteArray, 0, inputByteArray.Length);
  cs.FlushFinalBlock();
  StringBuilder ret = new StringBuilder();
  foreach (byte b in ms.ToArray())  
  {
  ret.AppendFormat("{0:X2}", b);
  }
  ret.ToString();
  return ret.ToString();

  }

  ///MD5解密 
  public static string MD5Decrypt(string pToDecrypt, string sKey)
  {
  DESCryptoServiceProvider des = new DESCryptoServiceProvider();

  byte[] inputByteArray = new byte[pToDecrypt.Length / 2];
  for (int x = 0; x < pToDecrypt.Length / 2; x++)
  {
  int i = (Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16));
  inputByteArray[x] = (byte)i;
  }

  des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
  des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
  MemoryStream ms = new MemoryStream();
  CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
  cs.Write(inputByteArray, 0, inputByteArray.Length);
  cs.FlushFinalBlock();

  StringBuilder ret = new StringBuilder();

  return System.Text.Encoding.Default.GetString(ms.ToArray());
  }
}

-------------------------------------------------------------------------------------------------

使用:

string IPassword = MD5Help.MD5Encrypt(password, ConfigurationManager.AppSettings["sKey"].ToString()); //加密
string JPassword = MD5Help.MD5Decrypt(Password, ConfigurationManager.AppSettings["sKey"].ToString()); //解密

webConfig配置:

<!--Md5加密key-->
<add key="sKey" value="JUNDAOXT"/>

C#中DataTable删除多条数据

 

//一般情况下我们会这么删除

DataTable dt = new DataTable();

for (int i = 0; i < dt.Rows.Count; i++)

{

if (99 % i == 0)

{

dt.Rows.RemoveAt(i);

}

}

//但是这么删除会出现意外情况

//当运行dt.Rows.RemoveAt(i)代码后DataTable的index会发生改变

//且他的dt.Rows.Count也会改变

//正确做法一

for (int i = dt.Rows.Count - 1; i >= 0; i--)

{

if (99 % i == 0)

{

dt.Rows.RemoveAt(i);

}

}

//正确做法二

for (int i = 0; i < dt.Rows.Count; i++)

{

if (99 % i == 0)

{

dt.Rows[i].Delete();

}

}

dt.AcceptChanges();//提交

//dt.RejectChanges();//回滚个人笔记

SELECT INTO和INSERT INTO SELECT的区别 类似aaa?a=1&b=2&c=3&d=4,如何将问号以后的数据变为键值对 C# 获取一定区间的随即数 0、1两个值除随机数以外的取值方法(0、1两个值被取值的概率相等) C# MD5 加密,解密 C#中DataTable删除多条数据的更多相关文章

  1. C#中DataTable删除多条数据

    //一般情况下我们会这么删除 DataTable dt = new DataTable(); for (int i = 0; i < dt.Rows.Count; i++) { if (99 % ...

  2. C# 获取一定区间的随即数 0、1两个值除随机数以外的取值方法(0、1两个值被取值的概率相等)

    获取随机数 举例:0-9 Random random = new Random(); int j = random.Next(0, 9); 0.1两个值被取值的概率相等 int a = Math.Ab ...

  3. SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解(SQL数据库和Oracle数据库的区别)

    https://www.cnblogs.com/mq0036/p/4155136.html 我们经常会遇到需要表复制的情况,如将一个table1的数据的部分字段复制到table2中,或者将整个tabl ...

  4. sql-实现select取行号、分组后在分组内排序、每个分组中的前n条数据

    表结构设计: 实现select取行号 sql局部变量的2种方式 set @name='cm3333f'; select @id:=1; 区别:set 可以用=号赋值,而select 不行,必须使用:= ...

  5. oracle SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解

    我们经常会遇到需要表复制的情况,如将一个table1的数据的部分字段复制到table2中,或者将整个table1复制到table2中,这时候我们就要使用SELECT INTO 和 INSERT INT ...

  6. SELECT INTO 和 INSERT INTO SELECT

    做数据库开发的过程中难免会遇到有表数据备份的,而SELECT INTO……和INSERT INTO SELECT…… 这两种语句就是用来进行表数据复制,下面简单的介绍下: 1.INSERT INTO ...

  7. 问题:oracle select into;结果:oracle SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解

    oracle SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解 (2011-07-08 08:59:47) 转载▼ 标签: it 分类: oracle 我们经常会遇 ...

  8. SELECT INTO 和 INSERT INTO SELECT 两种表复制语句

    Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少.但我 ...

  9. SELECT INTO 和 INSERT INTO SELECT 两种表复制语句.txt

    Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少.但我 ...

随机推荐

  1. python爬虫积累(一)--------selenium+python+PhantomJS的使用(转)

    阅读目录 一.Selenium介绍 二.爬虫为什么要用selenium? 三.PhantomJS介绍 四.PhantomJS安装 五.操作实战 六.在此推荐虫师博客的学习资料 selenium + p ...

  2. 1301 邻值查找(set 平衡树 | 链表)

    描述 给定一个长度为 n 的序列 A,A 中的数各不相同.对于 A 中的每一个数 A_i,求: min(1≤j<i) ⁡|A_i-A_j| 以及令上式取到最小值的 j(记为 P_i).若最小值点 ...

  3. Stm32串口通信(USART)

    Stm32串口通信(UART) 串口通信的分类 串口通信三种传递方式 串口通信的通信方式 串行通信的方式: 异步通信:它用一个起始位表示字符的开始,用停止位表示字符的结束.其每帧的格式如下: 在一帧格 ...

  4. node.js爬取数据并定时发送HTML邮件

    node.js是前端程序员不可不学的一个框架,我们可以通过它来爬取数据.发送邮件.存取数据等等.下面我们通过koa2框架简单的只有一个小爬虫并使用定时任务来发送小邮件! 首先我们先来看一下效果图 差不 ...

  5. 基于335X的UBOOT网口驱动分析

    基于335X的UBOOT网口驱动分析 一.软硬件平台资料 1.  开发板:创龙AM3359核心板,网口采用RMII形式 2.  UBOOT版本:U-Boot-2016.05,采用FDT和DM. 参考链 ...

  6. 湖南大学第十四届ACM程序设计新生杯(重现赛)

    RANK  0 题数 0 期末复习没有参加,补几道喜欢的题. A: AFei Loves Magic  签到 思路 :不需考虑 碰撞 直接计算最终状态即可. #include<bits/stdc ...

  7. UVA 2519 Radar Installtion

    思路: #include<cstdio> #include<iostream> #include<cmath> #include<algorithm> ...

  8. Python内存管理以及数据类型

    一.内存管理 1.Cpython解释器的垃圾回收机制 什么是垃圾:当一个值身上没有绑定任何变量名(该值的引用计数=0)时,该值就是一个垃圾. Cpython解释器就会自动回收这样的垃圾. #引用计数增 ...

  9. Redis初步整理

    1,Redis 简介 Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. Redis 与其他 key - value 缓存产品有以下三个特点: Redis支持数据的 ...

  10. LeetCode(283. 移动零)

    问题描述 给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序. 示例: 输入: [0,1,0,3,12] 输出: [1,3,12,0,0] 说明: 必须在原数 ...