Аркановый мастер
Я разрабатываю Android уже почти 5 лет, и в последнее время я не очень занят проектами.Я всегда думаю о чем-то в свободное время.Но, как мобильная разработка, я лично считаю, что необходимо изучать фоновую разработку , Поскольку компания разработана на языке Go, я понимаю язык Go. Через некоторое время я обнаружил силу языка Go. Основываясь на элегантном синтаксисе и мощном параллелизме, я начал свой путь обучения.
Мощный драйвер базы данных Golang
Разница между Go и PHP заключается в том, что Go официально не предоставляет драйверы баз данных, но определяет некоторые стандартные интерфейсы для разработки драйверов баз данных разработчиками. Разработайте соответствующий драйвер базы данных в соответствии с определенным интерфейсом. Это имеет преимущество. Поскольку код разработан в соответствии со стандартным интерфейсом, данные необходимо будет перенести в будущем. библиотека, никаких модификаций не требуется
Не несите чушь, чтобы использовать MySQL или sqlite3, нужно заранее установить драйвер базы данных
sqlite3
Установка виндовс 32
1, установите SQLite3. прибытьwoohoo.SQLite.org/download.Contracts…, найдите sqlite-dll-win32-x86-3071700.zip, загрузите и распакуйте его, а затем скопируйте файл dll внутри в каталог windows/system32.
2. Загрузите компилятор gcc. прибытьtdm-gcc.tdragon.net/download, скачатьtdm-gcc-4.7.1-2. Если это 64-битная версия, загрузите tdm64-gcc-4.7.1-3. Запустите этот исполняемый файл и установите компилятор gcc.
3. Запустите команду: GO GETGithub.com/matt-you/go-things..., установите драйвер sqlite3 для go и т. д.
установка 64 битной винды
1. Загрузите компилятор gcc. прибытьtdm-gcc.tdragon.net/download, скачатьtdm64-gcc-4.7.1-3. Запустите этот исполняемый файл и установите компилятор gcc.
2, запустите команду: go getGitHub.com/Matt-you/go-things…, установите драйвер sqlite3 для go и т. д.
MySQL
Скачать: драйвер MySQL для пакета database/sql в Go.
адрес гитхаба:
Адрес официального сайта:
Вы также можете выполнять команды в оболочке:
$ go get github.com/go-sql-driver/mysql
стадия разработки
https://github.com/Go-SQL-Driver/MySQL 支持database/sql,全部采用go写。
https://github.com/ziutek/mymysql 支持database/sql,也支持自定义的接口,全部采用go写。
https://github.com/Philio/GoMySQL 不支持database/sql,自定义接口,全部采用go写。
Возьмите MySQL в качестве примера:
использовать
Использование пакета sql лаконично и ясно:
1. Установите соединение
Первый — открытый,
БД, ошибка: = sql.Open("mysql", "пользователь:пароль@/имяБД")
объяснять:
db является указателем типа *sql.DB.В следующих операциях после использования db open фактическое соединение с базой данных не устанавливается.Фактическое соединение с базой данных завершается методом Ping. Кроме того, бд должна существовать на протяжении всего жизненного цикла программы, то есть как только программа запускается, бд получается через Open до завершения программы, а потом бд Closed, а не Open/Close часто. ошибка = db.Ping()
2. Основное использование
Основными методами БД являются:
-
Query выполняет операции запроса к базе данных, такие как оператор Select, возвращает *Rows
-
QueryRow выполняет операцию запроса, которая возвращает не более 1 строки в базе данных и возвращает *Row
-
PrePare подготавливает операцию запроса к базе данных и возвращает *Stmt для последующего запроса или выполнения. Этот Stmt может выполняться несколько раз или одновременно
-
Exec выполняет операторы базы данных, которые не возвращают никаких строк, например операции удаления.
Основной метод Stmt:
- Exec
- Query
- QueryRow
- Close
Использование аналогично БД
Основной метод строк:
- Колонны: возврат [] строка, имена столбцов
- Скан:
- Следующий:
- Закрывать:
详见:
http://golang.org/pkg/database/sql/
https://github.com/go-sql-driver/mysql/wiki/Examples
https://github.com/VividCortex/go-database-sql-tutorial
Примечание
Метод открытия базы данных Mysql:
1. Откройте диспетчер задач --> откройте службы --> найдите службу, имя службы которой --> Mysql --> запустите ее, все в порядке.
2, Ctrl + R ввод cmd. Если у вас настроен Mysql, вы можете ввести команду net start mysql
Простой тестовый пример разработки
//插入
func insert(db *sql.DB) {
stmt, err := db.Prepare("INSERT INTO user(username, password) VALUES(?, ?)")
defer stmt.Close()
if err != nil {
log.Println(err)
return
}
stmt.Exec("guotie", "guotie")
stmt.Exec("testuser", "123123")
}
var CURRENT_AGE = 20
var sex = "男"
//公共类,检查错误
func checkError(str string,err error) bool{
if err != nil{
fmt.Printf(str+" %s \b \n",err.Error())
panic(err)
return false
}
return true
}
func main() {
db, err := sql.Open("mysql", "root:yyh123@tcp(localhost:3306)/test?charset=utf8")
checkError("打开一个 数据库",err)
//创建数据库
//createDataBase(db)
//userDb(db)
createTable(db)
insertTableContent(db)
queryFromDb(db)
updataFromDb(db)
//deleteFromTabCase(db)
//dropTab(db)
}
//删除表
func dropTab(db *sql.DB) {
res ,erro := db.Exec("drop table tb_user")
if erro != nil{
panic(erro)
}
affect,erro := res.RowsAffected()
if erro != nil{
checkError("删除表\n",erro)
}
fmt.Printf("\n删除表成功 ,结果影响的行数是:%d\n",affect)
}
//删除表周中数据
func deleteFromTabCase(db *sql.DB) {
stmt ,err := db.Prepare("delete from tb_user where name = ?")
checkError("根据条件进行删除表",err)
res ,err := stmt.Exec("卡卡罗特")
if err!= nil{
panic(err)
}
affect, err := res.RowsAffected()
lastId, err := res.LastInsertId()
fmt.Printf("affect : %d lasetId: %d",affect,lastId)
}
//更新数据
func updataFromDb(db *sql.DB) {
stmt ,err := db.Prepare("update tb_user set name = ? where name = ?")
checkError("查询条件数据库",err)
result ,erro := stmt.Exec("卡卡罗特","yuer")
if erro != nil{
checkError("查询条件数据库",erro)
}
affect ,err := result.RowsAffected()
checkError("查询的结果",err)
fmt.Printf("更新的数据:%d",affect)
}
//查询数据
func queryFromDb(db *sql.DB) {
row, error := db.Query("select * from tb_user")
if checkError("查询数据库",error){
defer row.Close()
for row.Next(){
var id int
var name string
var age int
var sex string
var addr string
var tel string
row.Scan(&id,&name,&age,&sex,&addr,&tel)
fmt.Printf("查询到了: id: %d %s %d %s %s %s \n",id,name,age ,sex,addr,tel)
}
}
//row, error := db.Query("select * from tb_user")
}
//增加:既插入数据
func insertTableContent(db *sql.DB) {
//var userId int = utils.GetNowtimeMD5()
stmt ,err := db.Prepare("insert tb_user set id = ?, name = ? ,age = ?, sex = ?,addr = ?,tel=?;")
//stmt, err := db.Prepare("insert userinfo set username=?,departname=?,created=?,password=?,uid=?")
checkError("准备阶段,回准备要执行的sql操作,然后返回准备完毕的执行状态。",err)
if CURRENT_AGE % 2 == 0{
sex = "男"
}else{
sex = "女 "
}
CURRENT_AGE = CURRENT_AGE+utils.Generate_Randnum()
result, err :=stmt.Exec(CURRENT_AGE,"yuer",CURRENT_AGE,sex,"河南省商水县等城镇林村","13011007869")
if err != nil{
panic(err)
}
fmt.Println("插入数据成功",result)
}
//创建表
func createTable(db *sql.DB) {
_, err := db.Exec("CREATE TABLE IF NOT EXISTS tb_user(id int(10) primary key,name varchar(20),age int(10),sex varchar(5),addr varchar(64),tel varchar(11));")
if err != nil {
fmt.Println("create table failed:", err.Error())
return
}
fmt.Println("创建表成功啦~~")
//第二种方式
stmt, erro := db.Prepare(userDetail)
if erro != nil {
panic(erro)
}
_, err = stmt.Exec()
if err != nil {
panic(err)
}
}
func main1() {
db, err := sql.Open("mysql", "root:yyh123@tcp(10.2.0.215:3306)/test?charset=utf8")
if err != nil {
log.Fatalf("Open database error: %s\n", err)
}
defer db.Close()
err = db.Ping()
if err != nil {
log.Fatal(err)
}
insert(db)
rows, err := db.Query("select id, username from user where id = ?", 1)
if err != nil {
log.Println(err)
}
defer rows.Close()
var id int
var name string
for rows.Next() {
err := rows.Scan(&id, &name)
if err != nil {
log.Fatal(err)
}
log.Println(id, name)
}
err = rows.Err()
if err != nil {
log.Fatal(err)
}
}
Суммировать
Сегодняшнее резюме — это верхушка айсберга разработки на го, и нам предстоит еще многому научиться. Причина, по которой я изучил Go, связана с потребностями компании и моим собственным планированием будущей карьеры. Хотя это по-прежнему в основном разработка для Android, моя личная энергия часто направляется на работу. Я также создал группу для общения в WeChat. Если вам также интересно , вы можете обсудить идти вместе.
читать далее
Помимо программистов, помимо написания хорошего кода, вы должны научиться и этим!
Android: Вы действительно понимаете преимущества и недостатки четырех основных архитектур?
Испытайте кокетливое программирование языка golang
Борьба с проектом NDK - высокая имитация 360 мобильных помощников Uninstall Monitor
Верь в себя, нет ничего невозможного, только неожиданное
Здесь вы найдете не только технологии!