黑马程序员—学习小心知识整理

时间:2022-12-08 21:43:55

------- Windows Phone 7手机开发.Net培训、期待与您交流! -------

 

知识一:SQL中char、varchar、text和nchar、nvarchar、ntext的区别
     1、CHAR。CHAR存储定长数据很方便,CHAR字段上的索引效率级高,比如定义char(10),那么不论你存储的数据是否达到了10个字节,都要占去10个字节的空间。
     2、VARCHAR。存储变长数据,但存储效率没有CHAR高。如果一个字段可能的值是不固定长度的,我们只知道它不可能超过10个字符,把它定义为 VARCHAR(10)是最合算的。VARCHAR类型的实际长度是它的值的实际长度+1。为什么“+1”呢?这一个字节用于保存实际使用了多大的长度。
    从空间上考虑,用varchar合适;从效率上考虑,用char合适,关键是根据实际情况找到权衡点。
    3、TEXT。text存储可变长度的非Unicode数据,最大长度为2^31-1(2,147,483,647)个字符。
    4、NCHAR、NVARCHAR、NTEXT。这三种从名字上看比前面三种多了个“N”。它表示存储的是Unicode数据类型的字符。我们知道字符中,英文字符只需要一个字节存储就足够了,但汉字众多,需要两个字节存储,英文与汉字同时存在时容易造成混乱,Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。nchar、nvarchar的长度是在1到4000之间。和char、varchar比较起来,nchar、nvarchar则最多存储4000个字符,不论是英文还是汉字;而char、varchar最多能存储8000个英文,4000个汉字。可以看出使用nchar、nvarchar数据类型时不用担心输入的字符是英文还是汉字,较为方便,但在存储英文时数量上有些损失。
     所以一般来说,如果含有中文字符,用nchar/nvarchar,如果纯英文和数字,用char/varchar。
     如果是存储文章等大段内容的时候,纯英文和数字,用text,含有中文字符的,用ntext。

 

知识二:EMAIL的合法性判断的一个快速简易方法

email.split('@');

该方法中email为要判断的字符串,判断一个字符串是否为email的最快(自然不准确)方法可以用split('@')将其根据@拆分,如果拆分结果为2部分,那可以粗略判断是emai地址。

 

知识三:控制台应用程序中的占位符

格式化常用占位符
{0}{1}字符串里的占位符
用法:string.Foramt("{0}{1}","黑马","程序员");//得到:黑马程序员

"yyyy-MM-dd HH:mm:ss"、"yyyy/MM/dd HH:mm:ss"... 日期时间格式化

用法:DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");//得到当前时间且格式化为(示例):2009-2-12 13:38:30

".00"数字格式化,更多请参考 NumberFormatInfo 类
用法:3.1415926f.ToString(".00");//得到:3.14


格式占位符(%)可以以下字母配合使用用来表示某些特定的输入输出。

%a,%A 读入一个浮点值(仅C99有效)   

%c 读入一个字符   

%d 读入十进制整数   

%i 读入十进制,八进制,十六进制整数   

%o 读入八进制整数   

%x,%X 读入十六进制整数   

%s 读入一个字符串,遇空格、制表符或换行符结束   

%f,%F,%e,%E,%g,%G 用来输入实数,可以用小数形式或指数形式输入。   

%p 读入一个指针 

%u 读入一个无符号十进制整数   

%n 至此已读入值的等价字符数  

%[] 扫描字符集合   

%% 读%符号

格式输入输出示例
scanf("%d,%d,%d",&a,&b,&c); // 从键盘输入三个整数,用逗号分隔   scanf("%c", &s); //从键盘输入一个字符   
scanf("%f", &f); //从键盘输入一个浮点型数据    printf("%d\n",a); //输出一个整数   
printf("%f\n",b); //输出一个浮点数   printf("%s\n",c); //输出一个字符   其中\n表示换行

 


------- Windows Phone 7手机开发.Net培训、期待与您交流! -------