精华内容
下载资源
问答
  • SQL数据库字段数据类型说明

    千次阅读 2018-03-15 23:23:47
    SQL数据库常用字段数据类型说明这里先总结数据类型。MySQL中的数据类型大的方面来分,可以分为:日期和时间、数值,以及字符串。下面就分开来进行总结。日期和时间数据类型MySQL数据类型含义date3字节,日期,格式:...

    SQL数据库常用字段数据类型说明

    这里先总结数据类型。MySQL中的数据类型大的方面来分,可以分为:日期和时间、数值,以及字符串。下面就分开来进行总结。

    日期和时间数据类型


    MySQL数据类型含义
    date3字节,日期,格式:2014-09-18
    time3字节,时间,格式:08:42:30
    datetime8字节,日期时间,格式:2014-09-18 08:42:30
    timestamp4字节,自动存储记录修改的时间
    year1字节,年份

    数值数据类型

    整型

    MySQL数据类型含义(有符号)
    tinyint1字节,范围(-128~127)
    smallint2字节,范围(-32768~32767)
    mediumint3字节,范围(-8388608~8388607)
    int4字节,范围(-2147483648~2147483647)
    bigint8字节,范围(+-9.22*10的18次方)

    上面定义的都是有符号的,当然了,也可以加上unsigned关键字,定义成无符号的类型,那么对应的取值范围就要翻翻了,比如:

    tinyint unsigned的取值范围为0~255。

    浮点型

    MySQL数据类型含义
    float(m, d)4字节,单精度浮点型,m总个数,d小数位
    double(m, d)8字节,双精度浮点型,m总个数,d小数位
    decimal(m, d)decimal是存储为字符串的浮点数

    我在MySQL中建立了一个表,有一列为float(5, 3);做了以下试验:

    1.插入123.45678,最后查询得到的结果为99.999;
    2.插入123.456,最后查询结果为99.999;
    3.插入12.34567,最后查询结果为12.346;

    所以,在使用浮点型的时候,还是要注意陷阱的,要以插入数据库中的实际结果为准。

    字符串数据类型

    MySQL数据类型含义
    char(n)固定长度,最多255个字符
    varchar(n)可变长度,最多65535个字符
    tinytext可变长度,最多255个字符
    text可变长度,最多65535个字符
    mediumtext可变长度,最多2的24次方-1个字符
    longtext可变长度,最多2的32次方-1个字符

    1.char(n)和varchar(n)中括号中n代表字符的个数,并不代表字节个数,所以当使用了中文的时候(UTF8)意味着可以插入m个中文,但是实际会占用m*3个字节。
    2.同时char和varchar最大的区别就在于char不管实际value都会占用n个字符的空间,而varchar只会占用实际字符应该占用的空间+1,并且实际空间+1<=n。
    3.超过char和varchar的n设置后,字符串会被截断。
    4.char的上限为255字节,varchar的上限65535字节,text的上限为65535。
    5.char在存储的时候会截断尾部的空格,varchar和text不会。
    6.varchar会使用1-3个字节来存储长度,text不会。

    其它类型

    1.enum(“member1″, “member2″, … “member65535″)
    enum数据类型就是定义了一种枚举,最多包含65535个不同的成员。当定义了一个enum的列时,该列的值限制为列定义中声明的值。如果列声明包含NULL属性,则NULL将被认为是一个有效值,并且是默认值。如果声明了NOT NULL,则列表的第一个成员是默认值。

    2.set(“member”, “member2″, … “member64″)
    set数据类型为指定一组预定义值中的零个或多个值提供了一种方法,这组值最多包括64个成员。值的选择限制为列定义中声明的值。

    数据类型属性

    上面大概总结了MySQL中的数据类型,当然了,上面的总结肯定是不全面的,如果要非常全面的总结这些内容,好几篇文章都不够的。下面就再来总结一些常用的属性。

    1.auto_increment

    auto_increment能为新插入的行赋一个唯一的整数标识符。为列赋此属性将为每个新插入的行赋值为上一次插入的ID+1。

    MySQL要求将auto_increment属性用于作为主键的列。此外,每个表只允许有一个auto_increment列。例如:

    代码如下:

    id smallint not null auto_increment primary key

    2.binary

    binary属性只用于char和varchar值。当为列指定了该属性时,将以区分大小写的方式排序。与之相反,忽略binary属性时,将使用不区分大小写的方式排序。例如:

    代码如下:

    hostname char(25) binary not null

    3.default

    default属性确保在没有任何值可用的情况下,赋予某个常量值,这个值必须是常量,因为MySQL不允许插入函数或表达式值。此外,此属性无法用于BLOB或TEXT列。如果已经为此列指定了NULL属性,没有指定默认值时默认值将为NULL,否则默认值将依赖于字段的数据类型。例如:

    代码如下:

    subscribed enum('0', '1') not null default '0'

    4.index

    如果所有其他因素都相同,要加速数据库查询,使用索引通常是最重要的一个步骤。索引一个列会为该列创建一个有序的键数组,每个键指向其相应的表行。以后针对输入条件可以搜索这个有序的键数组,与搜索整个未索引的表相比,这将在性能方面得到极大的提升。

    代码如下:

    create table employees
    (
    id varchar(9) not null,
    firstname varchar(15) not null,
    lastname varchar(25) not null,
    email varchar(45) not null,
    phone varchar(10) not null,
    index lastname(lastname),
    primary key(id)
    );

    我们也可以利用MySQL的create index命令在创建表之后增加索引:
    代码如下:

    create index lastname on employees (lastname(7));

    这一次只索引了名字的前7个字符,因为可能不需要其它字母来区分不同的名字。因为使用较小的索引时性能更好,所以应当在实践中尽量使用小的索引。

    5.not null

    如果将一个列定义为not null,将不允许向该列插入null值。建议在重要情况下始终使用not null属性,因为它提供了一个基本验证,确保已经向查询传递了所有必要的值。

    6.null

    为列指定null属性时,该列可以保持为空,而不论行中其它列是否已经被填充。记住,null精确的说法是“无”,而不是空字符串或0。

    7.primary key

    primary key属性用于确保指定行的唯一性。指定为主键的列中,值不能重复,也不能为空。为指定为主键的列赋予auto_increment属性是很常见的,因为此列不必与行数据有任何关系,而只是作为一个唯一标识符。主键又分为以下两种:

    (1)单字段主键

    如果输入到数据库中的每行都已经有不可修改的唯一标识符,一般会使用单字段主键。注意,此主键一旦设置就不能再修改。

    (2)多字段主键

    如果记录中任何一个字段都不可能保证唯一性,就可以使用多字段主键。这时,多个字段联合起来确保唯一性。如果出现这种情况,指定一个auto_increment整数作为主键是更好的办法。

    8.unique

    被赋予unique属性的列将确保所有值都有不同的值,只是null值可以重复。一般会指定一个列为unique,以确保该列的所有值都不同。例如:

    代码如下:

    email varchar(45) unique

    9.zerofill

    zerofill属性可用于任何数值类型,用0填充所有剩余字段空间。例如,无符号int的默认宽度是10;因此,当“零填充”的int值为4时,将表示它为0000000004。例如:

    代码如下:

    orderid int unsigned zerofill not null


    展开全文
  • sql数据库字段中的NULL都替换为空

    千次阅读 2019-07-25 09:25:17
    NULL与空字符串 ‘’ 是相同的?????...将sql数据库字段中的NULL都替换为空 UPDATE Table SET name = Null WHERE name = '' 将sql数据库字段中的空都替换为null UPDATE Table SET name = '' ...

    NULL空字符串 ‘’ 是相同的?????
    在MySQL中,这两者是完全不同的。NULL是指没有值,而”则表示值是存在的,只不过是个空值。(在Oracle中是相同的)

    1. 将sql数据库字段中的NULL都替换为空
    2. UPDATE Table SET name = Null WHERE name = ''
    3. 将sql数据库字段中的空都替换为null
    4. UPDATE Table SET name = '' WHERE name IS NULL
      值得注意的是,在判断Null时用的是 “ is ” 而不是 “ = ”;
      ⭐⭐⭐⭐MySQL中NULL与空字符串⭐⭐⭐⭐
    展开全文
  • sqlite数据库字段类型

    千次阅读 2020-03-25 14:30:39
    数据库字段类型: 字符型字段 topic=models.CharField(max_length=)#需要传入参数,设置字符串的最长长度 email=models.EmailTield()#电子邮箱字段,在CharField基础上,增加了邮箱的正则验证 a=models.SlugField()#...

    数据库字段类型:
    字符型字段

    topic=models.CharField(max_length=)#需要传入参数,设置字符串的最长长度
    email=models.EmailTield()#电子邮箱字段,在CharField基础上,增加了邮箱的正则验证
    a=models.SlugField()#仅含有字母下划线数字和连字符的字符串
    url=models.URLField()#url字段,默认长度200字符
    field=models.FieldPathField()#文件路径字段存储文件路径
    text=models.TextField()存储大量文本
    

    布尔类型字段:

    bool=models.BooleanField(null=)#传参值为设置是否可空
    

    日期字符串:

    datetime=models.DateTimeField()#日期时间字段可以传入两个参数值。auto_now每次更新对象时,都会更新此字段。auto_now_add为创建对象时保存的时间
    date=models.DateTimeField()#可选参数与上一个相同
    time=models.TimeField()#可选参数与上一个相同
    during=models.DurationField()储存时间段的字段
    

    文件类型字段:

    field=models.FileField()#上传文件字段,upload_to指定上传文件的路径字段,storage参数用于指定使用的存储引擎
    image=models.ImageField()#在FileField的基础上添加图片的校验
    
    key=models.ForeignKey()#多对一关系,与其他数据相关联需要传递参数on_delete参数指明当关联对象被删除,该对象的行为
    

    相关字段的参数:

    null#此参数设置此字段是否可空
    blank#此参数为true时,此字段输入框可以留空
    choices#此参数必须接收一个元组或者列表,在填写时,可供选择
    default#此参数设置默认值
    unique#此参数如果为true则会保持该字段数据唯一
    verbose_name#设置字段名称,可以在admin中显示更易懂的文字
    
    展开全文
  • 当我们定义数据库字段时,可能会在不经意间定义了和数据库关键字名相同的字段,这时我们在对该字段进行操作时,常会发生错误。例如我在表中定义了一个from字段,我们知道 from值mysql的关键字,所以我们在执行查询...

    当我们定义数据库的字段时,可能会在不经意间定义了和数据库关键字名相同的字段,这时我们在对该字段进行操作时,常会发生错误。

    例如我在表中定义了一个from字段,我们知道 from值mysql的关键字,所以我们在执行查询时

     SELECT * FROM WHERE from = 'xxx';

    就会报错,其解决办法有

    1.重新定义字段。
    2.用反撇号(`)包住待操作的关键字,换成一下语句则不会报错(注意不是单引号)。

      SELECT * FROM WHERE `from` = 'xxx';
    展开全文
  • 批量修改SQL数据库字段

    千次阅读 2009-10-23 17:57:00
    正确的修改方法:sql批量修改字段内容的语句1、没试过,网上搜索的 引用update 表名 set 要修改字段名 = replace (要修改字段名,被替换的特定字符,替换成的字符)2、自己按照一个一个修改是看数据表总结的例如偶修改...
  • Access中的数据类型  Access中有10中数据类型:文本、备注、数值、日期/时间、货币、自动编号、是/否、OLE对象、超级链接...这种类型允许最大255个字符或数字,Access默认的大小是50个字符,而且系统只保存输入到字段
  • 常见数据库字段类型与java.sql.Types的对应 Oracle与java.sql.Types的对应 Oracle java.sql.Types blob blob char
  • ![在图中表格里获取SQL数据](https://img-ask.csdn.net/upload/201505/09/1431172087_618570.jpg) ...数据库名:hy2006qt 表名:trans 四个字段:系统时间(date) 房间号(room) 账项代码(tanascode) 房费(amount)
  • SQL server 数据库 修改字段类型

    万次阅读 2019-08-16 16:14:16
    alter table表名alter column字段名称类型not null
  • java实体注解映射mysql数据库设置数据库字段类型以及时间格式 下面我们来说一下如何通过在java实体类注解设置数据库字段的类型 @SuppressWarnings(“serial”) @Entity @Table(name = “k_dailyWorkTasks”) public ...
  • pg 数据库中 某字段类型为jsonJava实体中对应类型是 jsonObject private JSONObject info;在mybatis的xml中,常规无法直接进行映射,需要自己写一个TypeHandler,自定义一个JSONTypeHandlerPg类具体代码:package ...
  • sql数据库类型为text 字段,中文存进去显示的是问号,请问如何解决?有人说是提前做好 编码工作,但是该怎样编码
  • 数据库字段类型和java的对应关系

    千次阅读 2017-03-02 14:47:02
    由于 SQL 数据类型和 Java 数据类型是不同的,因此需要某种机制在使用 Java 类型的应用程序和使用 SQL 类型数据库之间来读写数据。 为此,JDBC 提供了 getXXX 和 setXXX 方法集、方法 registerOutParameter...
  • 映射表如下:下面就举个例子来讲(JAVA插入MySql的datetime类型的简单的例子):看了映射表可知:我们可以以Timestamp类型的值插入到数据库数据库中表的设计为这样(有两个字段,id为整型是主键,create_on为...
  • 读写SQL数据库Image字段

    千次阅读 2011-03-04 16:12:00
    转自:http://www.cnblogs.com/lhuser/articles/1768343.html<br />  <br />C# 读写SQL数据库Image字段2009-01-31 19:27 在用C#对数据库Image字段读写过程中,遇到了一些问题,在网上搜索发现此类问题...
  • 最近做的一个项目中,做数据库表与实体类映射时,在XML文件中编写代码时,发现Oracle等数据库字段和Java等语言中数据类型应该是一一对应的,对应如下: SQL数据类型 JDBC类型代码 标准的Java类型 Oracle...
  • 表是由sql server 转 为mysql , 字符类型的的所有字段都是longtext类型 , 将所有的longtext转为varcher类型
  • ACCESS数据库字段类型 是/否

    千次阅读 2008-09-22 15:34:00
    ACCESS数据库字段类型 是/否 值0代表是,-1代表否!
  • SQL数据库中各种字段类型的说明

    万次阅读 2007-08-10 05:28:00
    (1)char、varchar、text和nchar、nvarchar、ntext  char和varchar的长度都在1到8000之间,它们的区别在于char是定长字符数据,而varchar是变长字符数据。...在SQL Server中,real的同义词为float(24)。 
  • mssql 修改数据库字段类型

    千次阅读 2018-10-12 09:00:23
    alter table tablename alter column columnname decimal(18,9)
  • mysql数据库字段类型的选择原则

    千次阅读 2016-06-08 21:14:09
    数据库类型的选择对数据库的性能影响很大 1 . 数据类型会影响存储空间的开销2 . 数据类型会影响数据查询性能所以当一个数据类型可以有多种选择多种类型的时候,应该优先考虑数字类型,其次是日期或二进制类型,最后...
  • 传入数据类型是List<String> 数据库字段类型应该是什么 数据库SQL server
  • 问题描述:在SQL Server数据库中使用Date类型字段存放不带时间的日期yyyy-MM-dd,在使用Java读取时间时发现读取回来的字段日期值自动减少了两天。 解决方法是将date类型改成datetime类型
  • Oracle/SQL 修改字段类型和长度

    万次阅读 2016-05-25 11:48:31
    Oracle/SQL 修改字段类型和长度
  • 问题: 当改为空或0时,提交后时无法更改,仍显示改前数据!   原因:在mybatis映射文件中&lt;update&gt;方法: &lt;if test="orderAmount !...字段order_amount在数据库类型是de...
  • 数据库字段类型–HSQL

    千次阅读 2010-03-29 11:09:00
    数字类型tinyint,smallint,integer,bigint,numeric,decimal它们对应到java中的类型为byte,short,int,long,bigdecimal,bigdecimal。decimal和numeric类型对应于java.math.BigDecimal,可以有很多的小数位数。在hsql中...
  • SQL Server数据库中bit字段类型使用时的注意事项 本文我们主要介绍了SQL Server数据库中bit类型字段的使用的相关知识以及bit字段类型使用时的注意事项,希望能够对您有所帮助。 AD:51CTO 网+首届APP创新...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 696,866
精华内容 278,746
关键字:

sql数据库字段类型