我来给你做一个综合解释吧。在正常情况下。PHP脚本 HTML 已经浏览器 然后就是数据库。都有自己的字符集。何谓字符集。我想你如果是一个真正想热衷于学PHP那么你应该花一定的时间去了解一下字符集的问题。就好比我做第一个项目。因为字符集搞的死去活来。1PHP的字符集。一般PHP网页的是嵌套在html页面以内。那么如果在没有冲突的情况下可以使用header方面设置。比如<php header >3数据库的问题。mysql_query("set names gbk"); 这句话意思就是说,在 *** 作数据库的时候已这个字符集去读写。当然这个字符集要对应你的页面的字符集哦。4浏览器。浏览器的问题是最万恶的,因为每个浏览器默认的是gb2312当然不同的浏览器是不同的。所以要想成为一名优秀的程序员,写出优质的代码。你还得去了解每个浏览器的差别。当然目前是不需要的,当然这个问题你慢慢学习。写代码的过程中会慢慢了解到的。你要做的就是将所有使用字符集确保一致性
看你字段有多少个字,取最大的就行了
有汉字用nvarchar,一个汉字算1个字
全英文数字半角符号用varchar,一个字母算一个字
如果非要用varchar装汉字,一个汉字算2个字
解问题一
如果表包含在数据库中,即数据库表,可以在该表的逗表设计器地中,该字符型字段的逗输入掩码地文本框中输入与字段宽度等宽位数的逗9地,比如字段宽度为5,则输入掩码为逗99999地。
解问题二
这里有个概念,如果 INDEX 的<索引表达式>是单个字段
1、数值型字段,按照数值的大小升序排列
2、字符型字段,按照字符的ASCII值的大小升序排列
3、日期或日期时间型字段,按照日期的远近,从远到近排列
如果 INDEX 的<索引表达式>中包含多个字段,那么首先必须要能求出该表达式的值,然后才能做到按什么顺序排列,为了简化讨论,略过日期或日期时间型,因为日期或日期时间型必能通过函数转换成数值型或字符型数据
1、如果这多个字段都是数值型,则按照索引表达式的数值运算的值的大小升序排列
2、如果这多个字段都是字符型,则各字段联接(+或-)后,按照联接的顺序各字段依字符串的大小(按照ASCII)升序排列
3、如果这多个字段中有数值型也有字符型,则索引表达式应将其统一到同一数据类型。
举例:设表T1DBF,字段C1、C2为数值型,字段C3、C4为字符型
按C1+C2的和升序排列
INDEX ON C1+C2 TO T1
字段C3升序,相同时C4升序
INDEX ON C3+C4 TO T2
字段C1升序,相同时C2升序
INDEX ON STR(C1)+STR(C2) TO T3 && 将C1、C2都转成字符型,以字符串大小排列
字段C1升序,相同时C3升序
INDEX ON STR(C1)+C3 TO T4 && 将C1转成字符型,以字符串大小排列
字段C3升序,相同时C4降序
INDEX ON C3+STR(127-ASC(C4)) TO T5 && 127为ASCII的最大值
字段C1降序,相同时C3升序
INDEX ON STR(999-C1)+C3 TO T6 && 假设数值型字段C1的宽度为3位,999为该字段允许的最大值
sql取值范围数字字符怎么设置, *** 作方法如下。
设备:联想电脑
系统:win10
软件:SQL Server 2012
1、首先在打开的软件中,获取当前系统数据库的日期和时间,可以利用函数GETDATE(),select GETDATE()。
2、获取当前世界标准时间的日期时间值,利用GETUTCDATE()函数,select GETUTCDATE()。
3、获取某个日期时间中的日期,可以利用DAY()函数,select DAY(日期)。
4、最后获取日期中指定部分字符串值的,可以利用函数DATENAME()函数,如下图所示就完成了。
mysql 创建 数据库时指定编码很重要,很多开发者都使用了默认编码,乱码问题可是防不胜防。制定数据库的编码可以很大程度上避免倒入导出带来的乱码问题。
网页数据一般采用UTF8编码,而数据库默认为latin 。我们可以通过修改数据库默认编码方式为UTF8来减少数据库创建时的设置,也能最大限度的避免因粗心造成的乱码问题。
我们遵循的标准是,数据库,表,字段和页面或文本的编码要统一起来
我们可以通过命令查看数据库当前编码:
mysql> SHOW VARIABLES LIKE 'character%';
发现很多对应的都是 latin1,我们的目标就是在下次使用此命令时latin1能被UTF8取代。
第一阶段:
mysql设置编码命令
[sql] view plain copy
SET character_set_client = utf8;
SET character_set_connection = utf8;
SET character_set_database = utf8;
SET character_set_results = utf8;
SET character_set_server = utf8;
然后 mysql> SHOW VARIABLES LIKE 'character%'; 你可以看到全变为 utf8 。但是,这只是一种假象
此种方式只在当前状态下有效,当重启数据库服务后失效。
所以如果想要不出现乱码只有修改myini文件,
从myini下手(标签下没有的添加,有的修改)
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqld]
default-character-set=utf8
以上3个section都要加default-character-set=utf8,平时我们可能只加了mysqld一项。
然后重启mysql,执行
mysql> SHOW VARIABLES LIKE 'character%';
确保所有的Value项都是utf8即可。
但是可恶的事情又来了,
|character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | latin1 |
| character_set_system | utf8
注意 该配置| character_set_server | latin1 无法设置成UTF8 交互时候仍然会出现乱码。
第二阶段:找到下面这东东
X:\%path%\MySQL\MySQL Server 50\bin\MySQLInstanceConfigexe
重新启动设置,将默认编码设置为utf8这样就能达到我们所要的效果了。
mysql> SHOW VARIABLES LIKE 'character%';
+--------------------------+---------------------------------------------------------+
| Variable_name | Value |
+--------------------------+---------------------------------------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | C:\Program Files\MySQL\MySQL Server 50\share\charsets\ |
+--------------------------+---------------------------------------------------------+
8 rows in set
以DBA身份进入SQLPLUS SQL sqlplus sys/sys as sysdba; …… SQL shutdown immediate; SQL startup mount; SQL alter system enable restricted session; SQL alter system set job_queue_processes=0; SQL alter system set aq_tm_processes=0; SQL alter database open; SQL alter database character set internal_use AL32UTF8;(ZHS16GBK) SQL shutdown immediate; SQL startup; 这样就可以讲ORACLE的字符集修改为UTF8,如果需要修改为GBK只需将alter database character set internal_use AL32UTF8;(ZHS16GBK)这句最后的AL32UTF8修改为ZHS16GBK即可
以上就是关于php创建mysql数据库时候如何设置字符集全部的内容,包括:php创建mysql数据库时候如何设置字符集、关于SQL中字符长度的设置、VFP数据库表如何设置字符型字段只能输入数字字符等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)