① 数据库里设置字段的数据类型
可以直接用sql语句来啊
你在创建这些列名的时候直接在它后面加上数据类型就行
如:
create table table_name
(id int,username varchar(20),
password varchar(8),....)
这样就行了啊
② MySql数据类型有哪些
1. MySQL数据类型
在MySQL中有如下几种数据类型:
(1)数值型
数值是诸如32 或153.4 这样的值。MySQL 支持科学表示法,科学表示法由整数或浮点数后跟“e”或“E”、一个符号(“+”或“-”)和一个整数指数来表示。1.24E+12 和23.47e-1 都是合法的科学表示法表示的数。而1.24E12 不是合法的,因为指数前的符号未给出。
浮点数由整数部分、一个小数点和小数部分组成。整数部分和小数部分可以分别为空,但不能同时为空。
数值前可放一个负号“-”以表示负值。
(2)字符(串)型
字符型(也叫字符串型,简称串)是诸如“Hello, world!”或“一个馒头引起的血案”这样的值,或者是电话号码87398413这样的值。既可用单引号也可用双引号将串值括起来。
初学者往往分不清数值87398143和字符串87398143的区别。都是数字啊,怎么一 个要用数值型,一个要用字符型呢?关键就在于:数值型的87398143是要参与计算的,比如它是金融中的一个货款总额;而字符型的87398143是不 参与计算的,只是表示电话号码,这样的还有街道号码、门牌号码等等,它们都不参与计算。
(3)日期和时间型
日期和时间是一些诸如“2006-07-12”或“12:30:43”这样的值。MySQL还支持日期/时间的组合,如“2006-07-12 12:30:43”。
(4)NULL值
NULL表示未知值。比如填写表格中通讯地址不清楚留空不填写,这就是NULL值。
我们用Create Table语句创建一个表(参看前面的章节),这个表中包含列的定义。例如我们在前面创建了一个joke表,这个表中有content和writer两个列:
定义一个列的语法如下:
其中列名由col_name 给出。列名可最多包含64个字符,字符包括字母、数字、下划线及美元符号。列名可以名字中合法的任何符号(包括数字)开头。但列名不能完全由数字组成,因 为那样可能使其与MySQL数据类型分不开。MySQL保留诸如SELECT、DELETE和CREATE这样的词,这些词不能用做列名,但是函数名(如POS 和MIN)是可以使用的。
列类型col_type表示列可存储的特定值。列类型说明符还能表示存放在列中的值的最大长 度。对于某些类型,可用一个数值明确地说明其长度。而另外一些值,其长度由类型名蕴含。例如,CHAR(10) 明确指定了10个字符的长度,而TINYBLOB值隐含最大长度为255个字符。
有的类型说明符允许指定最大的显示宽度(即显示值时使用多少个字符)。浮 点类型允许指定小数位数,所以能控制浮点数的精度值为多少。
可以在列类型之后指定可选的类型说明属性,以及指定更多的常见属性。属性起修饰类型的作用,并更改其处理列值的方式,属性有以下类型:
(1)专用属性用于指定列。例如,UNSIGNED 属性只针对整型,而BINARY属性只用于CHAR 和VARCHAR。
(2)通用属性除少数列之外可用于任意列。可以指定NULL 或NOT NULL 以表示某个列是否能够存放NULL。还可以用DEFAULT,def_value 来表示在创建一个新行但未明确给出该列的值时,该列可赋予值def_value。def_value 必须为一个常量;它不能是表达式,也不能引用其他列。不能对BLOB 或TEXT 列指定缺省值。
如果想给出多个列的专用属性,可按任意顺序指定它们,只要它们跟在列类型之后、通用属性之前即可。类似地,如果需要给出多个通用属性,也可按任意顺序给出它们,只要将它们放在列类型和可能给出的列专用属性之后即可。
2. MySQL的列(字段)类型
数据库中的每个表都是由一个或多个列(字段)构成的。在用CREATE TABLE语句创建一个表时,要为每列(字段)指定一个类型。列(字段)的类型比MySQL数据类型更为细化,它精确地描述了给定表列(字段)可能包含的值的种类,如是否带小数、是否文字很多。
③ 濡備綍浣跨敤绯荤粺甯鍔╂煡鎵綧ySQL涓璬ouble鏁版嵁绫诲瀷鐨勪俊鎭,骞舵壘鍒癲ouble绫诲瀷鏈夌﹀彿鏁帮紵
浣犲彲浠ヤ娇鐢 MySQL 鐨勭郴缁熷府鍔╂潵鏌ユ壘 double 鏁版嵁绫诲瀷鐨勪俊鎭銆傚湪 MySQL 涓锛屽彲浠ヤ娇鐢 DESC 鍛戒护鏉ユ煡鐪嬭〃鐨勭粨鏋勪俊鎭锛屽寘鎷姣忎釜鍒楃殑鏁版嵁绫诲瀷銆
涓嬮潰鏄鏌ユ壘 double 鏁版嵁绫诲瀷淇℃伅鐨勬ラわ細
鎵撳紑 MySQL 鍛戒护琛屾垨鑰呭叾浠 MySQL 瀹㈡埛绔锛
杩炴帴鍒颁綘鐨 MySQL 鏁版嵁搴擄紱
閫夋嫨浣犺佹煡鎵句俊鎭鐨勬暟鎹搴擄細USE database_name;锛屽叾涓 database_name 鏄浣犺佹煡鎵句俊鎭鐨勬暟鎹搴撳悕锛
杈撳叆浠ヤ笅鍛戒护锛屾煡鐪嬭〃鐨勭粨鏋勪俊鎭锛欴ESC table_name;锛屽叾涓 table_name 鏄浣犺佹煡鎵句俊鎭鐨勮〃鍚嶏紱
鎵惧埌鏁版嵁绫诲瀷涓 double 鐨勫垪鍚嶏紝鍙浠ユ煡鐪嬪叾鏄鍚︿负鏈夌﹀彿鏁般
濡傛灉浣犳兂鏌ユ壘鎵鏈夌殑 double 鍒楀苟鍒楀嚭鍏舵湁绗﹀彿鏁扮殑淇℃伅锛屽彲浠ヤ娇鐢ㄤ互涓嬪懡浠わ細
SELECT COLUMN_NAME, COLUMN_TYPE, NUMERIC_SCALE, IS_NULLABLE, COLUMN_DEFAULT,
IF(COLUMN_TYPE LIKE '%unsigned%', 'unsigned', 'signed') AS 'sign'
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_SCHEMA = 'database_name' AND DATA_TYPE = 'double';
鍦ㄤ笂闈㈢殑鍛戒护涓锛屽皢 database_name 鏇挎崲鎴愪綘瑕佹煡鎵句俊鎭鐨勬暟鎹搴撳悕銆傝繖涓鍛戒护灏嗚繑鍥炴墍鏈夋暟鎹绫诲瀷涓 double 鐨勫垪鐨勪俊鎭锛屽寘鎷鍒楀悕銆佹暟鎹绫诲瀷銆佸皬鏁扮偣鍚庣殑浣嶆暟銆佹槸鍚﹀彲浠ヤ负绌恒侀粯璁ゅ间互鍙婃槸鍚︿负鏈夌﹀彿鏁般傚叾涓锛孖F(COLUMN_TYPE LIKE '%unsigned%', 'unsigned', 'signed') 璇鍙ュ皢鍒ゆ柇璇ュ垪鏄鍚︿负鏈夌﹀彿鏁帮紝濡傛灉璇ュ垪绫诲瀷涓鍖呭惈 unsigned锛屽垯杩斿洖 unsigned锛屽惁鍒欒繑鍥 signed銆
④ mysql 数据库varchar可以存储多少个汉字和多少个数字
4.0版本以下,varchar(50),指的是50字节,如果存放UTF8汉字时,只能存16个(每个汉字3字节) 5.0版本以上,varchar(50),指的是50字符,无论存放的是数字、字母还是UTF8汉字(每个汉字3字节),都可以存放50个 其实最好的办法是在自己数据库中建个表试试可以放多少汉字,现在mysql都5.0已上了,varchar(50)是可以存50个汉字的
具体还是要看版本的:
4.0版本以下,varchar(100),指的是100字节,如果存放UTF8汉字时,只能存33个(每个汉字3字节)
5.0版本以上,varchar(100),指的是100字符,无论存放的是数字、字母还是UTF8汉字(每个汉字3字节),都可以存放100个。