C#中string型字段的区别 (char、varchar、nchar、nvarchar)_string和nvarchar-程序员宅基地

技术标签: 数据库  

源地址:http://www.cnblogs.com/mekong/archive/2009/04/17/1437996.html

对于程序中的string型字段,SQLServer中有char、varchar、nchar、nvarchar四种类型来对应(暂时不考虑text和ntext),开建立数据库中,对这四种类型往往比较模糊,这里做一下对比。

  1. 定长或变长
    所谓定长就是长度固定的,当输入的数据长度没有达到指定的长度时将自动以英文空格在其后面填充,使长度达到相应的长度;有var前缀的,表示是实际存储空间是变长的,比如varchar,nvarchar变长字符数据则不会以空格填充,比较例外的是,text存储的也是可变长。
  2. Unicode或非Unicode
    数据库中,英文字符只需要一个字节存储就足够了,但汉字和其他众多非英文字符,则需要两个字节存储。如果英文与汉字同时存在,由于占用空间数不同,容易造成混乱,导致读取出来的字符串是乱码。Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。而前缀n就表示Unicode字符,比如nchar,nvarchar,这两种类型使用了Unicode字符集。
  3. 基于以上两点来看看字段容量
    char,varchar 最多8000个英文,4000个汉字
    nchar,nvarchar 可存储4000个字符,无论英文还是汉字
  4. 使用(个人偏好)
    如果数据量非常大,又能100%确定长度且保存只是ansi字符,那么char
    能确定长度又不一定是ansi字符或者,那么用nchar
    对于超大数据,如文章内容,使用nText
    其他的通用nvarchar

char、varchar、nchar、nvarchar特点比较

  • CHAR
    CHAR
    存储定长数据很方便,CHAR字段上的索引效率级高,比如定义char(10),那么不论你存储的数据是否达到了10个字节,都要占去10个字节的空间。
  • VARCHAR
    存储变长数据,但存储效率没有CHAR,如果一个字段可能的值是不固定长度的,我们只知道它不可能超过10个字符,把它定义为 VARCHAR(10)是最合算的。VARCHAR类型的实际长度是它的值的实际长度+1。为什么"+1"呢?这一个字节用于保存实际使用了多大的长度。

从空间上考虑,用varchar合适;从效率上考虑,用char合适,关键是根据实际情况找到权衡点。

  • TEXT
    text
    存储可变长度的非Unicode数据,最大长度为2^31-1(2,147,483,647)个字符。
  • NCHAR、NVARCHAR、NTEXT
    这三种从名字上看比前面三种多了个"N"。和charvarchar比较起来,ncharnvarchar最多存储4000个字符,不论是英文还是汉字;而charvarchar最多能存储8000个英文,4000个汉字。可以看出使用ncharnvarchar数据类型时不用担心输入的字符是英文还是汉字,较为方便,但在存储英文时数量上有些损失。

所以一般来说,如果含有中文字符,用nchar/nvarchar,如果纯英文和数字,用char/varchar


版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/greyjoy16/article/details/8496910

智能推荐

数学模型用matlab表示,数学模型的MATLAB描述.ppt-程序员宅基地

文章浏览阅读287次。《数学模型的MATLAB描述.ppt》由会员分享,可在线阅读,更多相关《数学模型的MATLAB描述.ppt(45页珍藏版)》请在人人文库网上搜索。1、MATLAB语言与控制系统仿真,机电工程学院 School of Michanical & Electronical Engineering,蔡晓明,电话:13033399907 邮箱:cxm ,第二章 数学模型的MATLAB描述,1,C.1..._蔡晓明 13033399907

X-code 常用操作_x-code评级怎么做-程序员宅基地

文章浏览阅读1.5k次。新建项目command+shift+n切换双屏command+shift+enter_x-code评级怎么做

filebeat使用_filebeat单独使用-程序员宅基地

文章浏览阅读569次。为了充分利用elasticsearch的检索,及速度快; kibana的界面自动抽象,及交互能力,我们使用filebeat获取数据,如日志等,发送到elastic.暂时没有使用logstash,根据文献,就是它多了一个filter的功能,还要转一道,暂时不用。另修改var.path可以确定你要filebeat的日志的路径 。 记得enable:true.//todo : 还有一个f..._filebeat单独使用

Unix和Linux有什么区别?_unix和linux的区别-程序员宅基地

文章浏览阅读4.8k次。什么是Linux?Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和Unix的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的Unix工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。Unix和Linux有什么区别?Linux和Unix都是功能强大的操作系统,..._unix和linux的区别

Cisco跨vlan通信------单臂路由_g0/1口分成g/0.1和g0/0.2这是什么-程序员宅基地

文章浏览阅读1k次。拓扑如下:其中g0/0.1与g0/0.2是基于g0/0口(物理端口)的虚拟端口,又称子接口,若g0/0口坏掉,则其均不能工作。注意:encapsulation dot1Q 10 为封装协议,其中10要与Vlan号一样,即vlan10的网关要封装dot1Q 10,vlan20封装dot1Q 20,以此类推。PC1: ..._g0/1口分成g/0.1和g0/0.2这是什么

【CAS】Flask客户端配置_flask cas-程序员宅基地

文章浏览阅读3.7k次。CAS服务端配置,看这里本文基于Flask-CAS作为客户端与CAS服务端调试,测试多属性返回信息。1 环境说明Flask-CAS: 1.0.1Flask: 1.0.22 客户端工程目录#!/usr/bin/env python# -*- coding: utf-8 -*-"""__title__ = ''"""import sslimport flas..._flask cas

随便推点

HDOJ1000A + B Problem_a + b problem time limit: 2000 msmemory limit: 655-程序员宅基地

文章浏览阅读351次。A + B ProblemTime Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 638167 Accepted Submission(s): 199263Problem DescriptionCalculat_a + b problem time limit: 2000 msmemory limit: 65536 kb calculate a + b input t

【CAD-Web】CAD/DWG的Web化_dwg web-程序员宅基地

文章浏览阅读2.2w次,点赞18次,收藏70次。一、背景近期需要做个信息系统,能将一些2D的平面示意图(DWG格式文件)放到Web上,供放大、浏览,甚至可对元素进行交互,如点击、拖动、改变元素颜色线条等。于是,需要寻找开源的解析DWG格式的项目或者软件,一路下来,很是辛苦。这里记录下搜索到的有用信息。二、DWG与DXFDWG格式文件是Auto CAD软件的专有格式,类似于doc,是封闭的不开放的,且是二进制的。而 DXF格式则..._dwg web

VS中qt的include文件报错无法打开源文件问题解决办法----无法打开源文件QtWidgets/QApplication_vs转成qt项目后,include打不开了-程序员宅基地

文章浏览阅读1.8k次。换了一台电脑,把以前的qt文件迁移过来,手贱改了下sdk版本,qt的头文件就全找不到了1.将sdk设为10.02.来回切换下qt版本3.重启ide_vs转成qt项目后,include打不开了

web项目中扫描枪的应用_asp web 扫描枪-程序员宅基地

文章浏览阅读1w次。1. 页面有个输入框2. 扫描枪要设置自动Enter,这个说明书上应该有的3. 页面JQuery代码:$(document).keydown(function(event) { var keyCode = event.keyCode; if(keyCode == "13"){ var value = $("#elementId"); _asp web 扫描枪

java计算机毕业设计街舞公司管理系统MyBatis+系统+LW文档+源码+调试部署-程序员宅基地

文章浏览阅读180次。java计算机毕业设计街舞公司管理系统MyBatis+系统+LW文档+源码+调试部署。springboot基于SpringBoot的婚庆策划系统的设计与实现。ssm基于vue框架的疫情防控知识在线答题系统设计与实现。ssm基于HTML的“牧经校园疫情防控网站”的设计与实现。springboot体育馆预定管理平台的设计与实现。JSP网上测试系统的研究与设计sqlserver。JSP影城管理系统的设计与实现sqlserver。ssm基于Java智能选课系统的设计与实现。

PADS VX2.8 过孔盖油与不盖油的设置方法_pads过孔盖油怎么设置-程序员宅基地

文章浏览阅读2.7k次。在大多数的PCB设计过程中,过孔都需要盖油。方法一:打开PADSlayout界面,点击“设置”→“焊盘栈”,在“焊盘栈特性”窗口,正常添加一个过孔并修改“名称”、“直径”、“尺寸”等信息,此时的过孔是默认盖油的,操作如下图所示:添加并配置好过孔后,点击“添加”,在弹出的“添加层”选择“Solder Mask Top”和“Solder Mask Bottom”(顶层或底层都可以添加,根据项目需要)并修改“直径”,不盖油一般要外扩4mil或0.1mm。不盖油的过孔操作如下图所示:..._pads过孔盖油怎么设置

推荐文章

热门文章

相关标签