關於rubymysqldate的信息

本文目錄一覽:

mysql date函數怎麼用

以每24小時作為一份時間(而非自然日),根據用戶的配置有兩種工作模式:帶狀模式中,用戶僅定義開始日期時,從開始日期(含)開始,每份時間1個分片地無限增加下去;環狀模式中,用戶定義了開始日期和結束日期時,以結束日期(含)和開始日期(含)之間的時間份數作為分片總數(分片數量固定),以類似取模的方式路由到這些分片里。

1. DBLE 啟動時,讀取用戶在 rule.xml 配置的 sBeginDate 來確定起始時間

2. 讀取用戶在 rule.xml 配置的 sPartionDay 來確定每個 MySQL 分片承載多少天內的數據

3. 讀取用戶在 rule.xml 配置的 dateFormat 來確定分片索引的日期格式

4. 在 DBLE 的運行過程中,用戶訪問使用這個算法的表時,WHERE 子句中的分片索引值(字符串),會被提取出來嘗試轉換成 Java 內部的時間類型

5. 然後求分片索引值與起始時間的差,除以 MySQL 分片承載的天數,確定所屬分片

1. DBLE 啟動時,讀取用戶在 rule.xml 配置的起始時間 sBeginDate、終止時間 sEndDate 和每個 MySQL 分片承載多少天數據 sPartionDay

2. 根據用戶設置,建立起以 sBeginDate 開始,每 sPartionDay 天一個分片,直到 sEndDate 為止的一個環,把分片串聯串聯起來

3. 讀取用戶在 rule.xml 配置的 defaultNode

4. 在 DBLE 的運行過程中,用戶訪問使用這個算法的表時,WHERE 子句中的分片索引值(字符串),會被提取出來嘗試轉換成 Java 內部的日期類型

5. 然後求分片索引值與起始日期的差:如果分片索引值不早於 sBeginDate(哪怕晚於 sEndDate),就以 MySQL 分片承載的天數為模數,對分片索引值求模得到所屬分片;如果分片索引值早於 sBeginDate,就會被放到 defaultNode 分片上

與MyCat的類似分片算法對比

中間件

DBLE

MyCat

分片算法種類 date 分區算法 按日期(天)分片

兩種中間件的取模範圍分片算法使用上無差別

開發注意點

【分片索引】1. 必須是字符串,而且 java.text.SimpleDateFormat 能基於用戶指定的 dateFormat 來轉換成 java.util.Date

【分片索引】2. 提供帶狀模式和環狀模式兩種模式

【分片索引】3. 帶狀模式以 sBeginDate(含)起,以 86400000 毫秒(24 小時整)為一份,每 sPartionDay 份為一個分片,理論上分片數量可以無限增長,但是出現 sBeginDate 之前的數據而且沒有設定 defaultNode 的話,會路由失敗(如果有 defaultNode,則路由至 defaultNode)

【分片索引】4. 環狀模式以 86400000 毫秒(24 小時整)為一份,每 sPartionDay 份為一個分片,以 sBeginDate(含)到 sEndDate(含)的時間長度除以單個分片長度得到恆定的分片數量,但是出現 sBeginDate 之前的數據而且沒有設定 defaultNode 的話,會路由失敗(如果有 defaultNode,則路由至 defaultNode)

【分片索引】5. 無論哪種模式,分片索引字段的格式化字符串 dateFormat 由用戶指定

【分片索引】6. 無論哪種模式,劃分不是以日曆時間為準,無法對應自然月和自然年,且會受閏秒問題影響

運維注意點

【擴容】1. 帶狀模式中,隨着 sBeginDate 之後的數據出現,分片數量的增加無需再平衡

【擴容】2. 帶狀模式沒有自動增添分片的能力,需要運維手工提前增加分片;如果路由策略計算出的分片並不存在時,會導致失敗

【擴容】3. 環狀模式中,如果新舊 [sBeginDate,sEndDate] 之間有重疊,需要進行部分數據遷移;如果新舊 [sBeginDate,sEndDate] 之間沒有重疊,需要數據再平衡

配置注意點

【配置項】1. 在 rule.xml 中,可配置項為 propertyname=”sBeginDate” 、 propertyname=”sPartionDay” 、 propertyname=”dateFormat” 、 propertyname=”sEndDate” 和 propertyname=”defaultNode”

【配置項】2.在 rule.xml 中配置 propertyname=”dateFormat”,符合 java.text.SimpleDateFormat 規範的字符串,用於告知 DBLE 如何解析sBeginDate和sEndDate

【配置項】3.在 rule.xml 中配置 propertyname=”sBeginDate”,必須是符合 dateFormat 的日期字符串

【配置項】4.在 rule.xml 中配置 propertyname=”sEndDate”,必須是符合 dateFormat 的日期字符串;配置了該項使用的是環狀模式,若沒有配置該項則使用的是帶狀模式

【配置項】5.在 rule.xml 中配置 propertyname=”sPartionDay”,非負整數,該分片策略以 86400000 毫秒(24 小時整)作為一份,而 sPartionDay 告訴 DBLE 把每多少份放在同一個分片

【配置項】6.在 rule.xml 中配置 propertyname=”defaultNode” 標籤,非必須配置項,不配置該項的話,用戶的分片索引值沒落在 mapFile 定義

用ruby寫mysql,如果直接操作位元組流

直接寫入數據庫就好了,寫一個讀寫mysql的類文件接口,然後調用操作。具體如下,我調試過的。

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

require ‘mysql’

class MysqlDb

# attr_accessor :host, :user, :pass, :database

def open(host=nil, user=nil, pass=nil, database=nil,port=3306)

@host =host

@user = user

@pass = pass

@database = database

@port = port

begin

@connection = Mysql.new(@host, @user, @pass, @database, @port)

rescue

puts “connect faild! an error has occurred: #{$!}” # 錯誤信息保存在特殊變量$!中。

try_again

end

end

def try_again

puts ‘——————try again, if not modify, leave a blank—————‘

print “host: ”

host=STDIN.gets.strip

@host = check_value(host,@host)

puts “—————current host: #{@host}”

print “user: ”

user =STDIN.gets.strip

@user = check_value(user,@user)

puts “—————current user: #{@user}”

print “password: “

pass =STDIN.gets.strip

@pass = check_value(pass,@pass)

puts “—————current password: #{@pass}”

print “database: “

database =STDIN.gets.strip

@database = check_value(database,@database)

puts “—————current database: #{@database}”

print “port: “

port =STDIN.gets.strip

@port = check_value(port,@port)

open(@host, @user, @pass, @database, @port)

puts “—————current port: #{@port}”

end

def check_value(value,returnvalue)

if value == “”

nil

else

returnvalue = value

end

return returnvalue

end

def iquery(sql)

field = []

@connection.query(sql).each do |data|

field data

end

field.to_a

end

def iexecute(sql)

@connection.query(sql)

end

def close

@connection.close

end

end

# useages

adb = MysqlDb.new

adb.open(‘127.0.0.1′,’root’,’zyq001122′,’hello_z’,’3307′)

# result = db.query “insert into user value(7,\”lilY\”,\”256y42\”,\”#{Time.now.strftime(“%Y-%m-%d %H:%M:%S”)}\” )” # 插入記錄

# result.each {|row| puts row}

num_of_records = adb.iquery (‘select count(*) from user’) #查詢

puts num_of_records

#sql = “insert into user value(10,\”Hello-Kitty\”,\”256y42\”,\”#{Time.now.strftime(“%Y-%m-%d %H:%M:%S”)}\” )” # 數據操作

# sql = ‘update user set name=\’jackjhons\’ where uid=5 ‘ # 更新一條記錄

#adb.iexecute(sql)

# adb.close

ruby連接mysql報錯: Can’t connect to MySQL server on ‘localhost’ (10061)

mysql的服務沒有開,登錄到mysql服務器,ps -ef|grep mysqld看看,如果是windows下,執行 sc query mysql 看看服務狀態是什麼

原創文章,作者:簡單一點,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/130858.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
簡單一點的頭像簡單一點
上一篇 2024-10-03 23:27
下一篇 2024-10-03 23:27

相關推薦

  • Java 監控接口返回信息報錯信息怎麼處理

    本文將從多個方面對 Java 監控接口返回信息報錯信息的處理方法進行詳細的闡述,其中包括如何捕獲異常、如何使用日誌輸出錯誤信息、以及如何通過異常處理機制解決報錯問題等等。以下是詳細…

    編程 2025-04-29
  • 使用Python爬蟲獲取電影信息的實現方法

    本文將介紹如何使用Python編寫爬蟲程序,來獲取和處理電影數據。需要了解基本的Python編程語言知識,並使用BeautifulSoup庫和Requests庫進行爬取。 一、準備…

    編程 2025-04-28
  • Python爬取網頁信息

    本文將從多個方面對Python爬取網頁信息做詳細的闡述。 一、爬蟲介紹 爬蟲是一種自動化程序,可以模擬人對網頁進行訪問獲取信息的行為。通過編寫代碼,我們可以指定要獲取的信息,將其從…

    編程 2025-04-28
  • 如何使用Python執行Shell命令並獲取執行過程信息

    本文將介紹如何使用Python執行Shell命令並獲取執行過程信息。我們將從以下幾個方面進行闡述: 一、執行Shell命令 Python內置的subprocess模塊可以方便地執行…

    編程 2025-04-28
  • Python實現身份信息模擬生成與查驗

    本文將從以下幾個方面對Python實現身份信息模擬生成與查驗進行詳細闡述: 一、身份信息生成 身份信息生成是指通過代碼生成符合身份信息規範的虛假數據。Python中,我們可以使用f…

    編程 2025-04-27
  • Dapper使用getschema獲取表信息

    本文旨在介紹Dapper中使用getschema獲取表信息的方法和注意事項。 一、獲取某張表的所有列信息 使用Dapper獲取某張表信息,可以使用 `IDbConnection.G…

    編程 2025-04-27
  • 通過提交信息搜索-使用git

    本篇文章重點講解如何使用git通過提交信息來搜索。我們將從多個方面介紹如何使用git來搜索提交信息,並提供相應的代碼示例以供參考。 一、搜索方式 Git提供了三種搜索方式,分別為:…

    編程 2025-04-27
  • 已裝備我軍的空中信息化作戰平台

    本文將會從多個方面詳細闡述已裝備我軍的空中信息化作戰平台。 一、平台概述 已裝備我軍的空中信息化作戰平台是一個全新的作戰系統,具備實時數據採集、處理、分析、共享的能力。它可以在不同…

    編程 2025-04-27
  • Linux查看系統信息

    一、CPU信息 Linux系統下,查看CPU的信息最常用的命令是lscpu。該命令可以顯示CPU架構、核心數量、線程數、緩存大小、CPU頻率等信息。例如: lscpu 該命令會輸出…

    編程 2025-04-24
  • 軟考 信息安全工程師

    軟考 信息安全工程師是一項技能型國家級資格認證考試,主要測試考生在信息安全領域的理論知識和實踐技能,是證明個人信息安全能力的重要證書。本文將從多個方面對軟考 信息安全工程師做詳細的…

    編程 2025-04-23

發表回復

登錄後才能評論