VARCHAR是MySQL中常用的數(shù)據(jù)類型,但其單位究竟是字符還是字節(jié)呢?
專注于為中小企業(yè)提供成都做網(wǎng)站、成都網(wǎng)站設(shè)計服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)淳安免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了近千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
經(jīng)過查閱,MySQL的 官方文檔 給出了答案:
4.1及之后的版本,VARCHAR的單位是字符;4.1之前的版本,VARCHAR的單位是字節(jié)。(As of version 4.1 , MySQL interprets length specifications in character column definitions in character units . (Before MySQL 4.1, column lengths were interpreted in bytes .) This applies to CHAR, VARCHAR and the TEXT types.)
同時官方文檔也提到,4.1及之后的版本以UTF-8作為預(yù)定義字符集。(VARCHAR is shorthand for CHARACTER VARYING. NATIONAL VARCHAR is the standard SQL way to define that a VARCHAR column should use some predefined character set. MySQL 4.1 and up uses UTF8 as this predefined character set .)
在 Go 語言中,是不能用 len 函數(shù)來統(tǒng)計字符串中的字符個數(shù)的,這是因為在 Go 中,字符串是以 UTF-8 為格式進行存儲的,在字符串上調(diào)用 len 函數(shù),取得的是字符串包含的 byte 的個數(shù)。
那么如何在Go語言中獲取字符串中的字符個數(shù)呢?有下面幾種方法:
測試發(fā)現(xiàn)速度最快的是 utf8.RuneCountInString()
feof(),用這個函數(shù)判斷是否讀到文件尾了。fread(buf,size,count,fp);//buf輸入數(shù)據(jù)起始地址,size每個數(shù)據(jù)塊的大小,count每次寫入的數(shù)據(jù)塊個數(shù),fp文件指針寫好后是:while(!feof(fp)){fread(temp[i],sizeof(structuse),1,fp);//這個讀出來放數(shù)組里面i++;}問題是你讀的是txt文件,完全可以用fscanf()函數(shù)么。
package main
import (
"fmt"
"os"
)
func main() {
if len(os.Args) 2 {
fmt.Println("Please Input File Name!")
return
}
file, err := os.Open(os.Args[1])
if err != nil {
return
}
buff := make([]byte, 1000)
_, err = file.Read(buff)
if err != nil {
return
}
a, c, d, e, _ := Sum(buff)
fmt.Printf("a c d e \n%d %d %d %d\n", a, c, d, e)
}
func Sum(buff []byte) (a, c, d, e, def int) {
for i := 0; i len(buff); i++ {
switch buff[i] {
case 'a':
a++
case 'c':
c++
case 'd':
d++
case 'e':
e++
default:
def++
}
}
return
}
一般來說,我們不會直接使用ASCII碼來處理,因為這樣不夠直觀。比如你說的判定輸入是否是字母,是否是數(shù)字,那么有個比較直觀的方法來處理。如果你看過ASCII碼表,那么你就知道字數(shù)和字母在ASCII碼表中都是連續(xù)的,所以這個就比較好解決了。
判定字符ch是否是數(shù)字:
if(ch='0' ch='9')
判定字符ch是否是字母:
if(ch='a' ch='z' || ch='A' ch='Z')
當(dāng)然,有已經(jīng)定義好的庫函數(shù)用來判定是否數(shù)字和字母,不要加加載頭文件ctype.h
判定字符ch是否是數(shù)字:
if(isalnum(ch));
判定字符ch是否是字母:
if(isalpha(ch));
這兩個函數(shù)都是判定成立,結(jié)果是true也就是1,判定不成立,結(jié)果是false,也就是0.
1、基本數(shù)據(jù)類型
bool
string
int int8 int16 int32 int64
uint uint8 uint16 uint32 uint64 uintptr
byte // alias for int8
rune // alias for int32,represents a Unicode code point
float32 float64
complex64 complex128
常量定義
2、類型轉(zhuǎn)換
(1)Go語言不允許隱式類型轉(zhuǎn)換(不支持小位數(shù)類型向大位數(shù)類型轉(zhuǎn))
(2)別名和原有類型也不能進行隱式類型轉(zhuǎn)換(type MyInt int64 = int64)
3、類型的預(yù)定義值
1.math.MaxInt64
2.math.MaxFloat64
3.math.MaxUInt32
4、指針類型
(1)不支持指針運算
(2)string是值類型,其默認的初始化值為空字符串,而不是nil
5、算術(shù)運算符
+ - * / % ++ --(不支持前置++ --)
6、比較運算符
#== != = =
(1)比較數(shù)組
相同維數(shù)且含有形同個數(shù)元素的數(shù)組才可以比較
每個元素都相同的才相等
7、位運算符
| ^
^ (按位置零) a (^b)
1 ^ 0 1
1 ^ 1 0
0 ^ 1 0
0 ^ 0 0
8、條件與循環(huán)
(1)循環(huán)
Go 語?僅?持循環(huán)關(guān)鍵字 for
(2)條件
9、數(shù)組和切片
數(shù)組截取,索引下標(biāo)從0開始計數(shù)
a[開始索引(包含), 結(jié)束索引(不包含)]
a := [...]int{1, 2, 3, 4, 5}
a[1:2] //2
a[1:3] //2,3
a[1:len(a)] //2,3,4,5
a[1:] //2,3,4,5
a[:3] //1,2,3
切片內(nèi)部結(jié)構(gòu)
9、Map
9、字符串
Unicode UTF8
常?字符串函數(shù)
當(dāng)前文章:go語言統(tǒng)計字母個數(shù) go語言基本數(shù)據(jù)類型
轉(zhuǎn)載注明:http://m.kartarina.com/article18/hgjsgp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、關(guān)鍵詞優(yōu)化、網(wǎng)站策劃、云服務(wù)器、外貿(mào)建站、網(wǎng)站維護
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)